/* ====== Command Palette ====== */
.cp-overlay {
  position: fixed; inset: 0;
  background: color-mix(in oklab, var(--ink) 35%, transparent);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  z-index: 200;
  display: flex; align-items: flex-start; justify-content: center;
  padding-top: 11vh;
  animation: cpFade 0.16s ease;
}
@keyframes cpFade { from { opacity: 0; } to { opacity: 1; } }
@keyframes cpRise { from { opacity: 0; transform: translateY(-12px) scale(0.985); } to { opacity: 1; transform: none; } }

.cp-modal {
  width: min(680px, calc(100vw - 32px));
  max-height: 70vh;
  background: var(--parchment-deep);
  border: 1px solid var(--hairline);
  border-radius: 6px;
  box-shadow: 0 30px 80px -20px color-mix(in oklab, var(--ink) 40%, transparent),
              0 0 0 1px color-mix(in oklab, var(--gilt) 20%, transparent);
  display: flex; flex-direction: column;
  overflow: hidden;
  animation: cpRise 0.2s cubic-bezier(.2,.7,.2,1);
}

.cp-header {
  display: flex; align-items: center; gap: 14px;
  padding: 18px 20px;
  border-bottom: 1px solid var(--hairline-soft);
  background: color-mix(in oklab, var(--gilt) 4%, var(--parchment-deep));
}
.cp-glyph { color: var(--gilt-deep); display: inline-flex; }
.cp-input {
  flex: 1;
  background: transparent;
  border: 0; outline: none;
  font-family: var(--font-display);
  font-size: 22px;
  color: var(--ink);
  letter-spacing: 0.005em;
}
.cp-input::placeholder { color: var(--ink-faint); font-style: italic; }
.cp-esc {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-mute);
  border: 1px solid var(--hairline);
  padding: 4px 8px;
  border-radius: 2px;
}

.cp-results {
  flex: 1;
  overflow-y: auto;
  padding: 6px 0 8px;
  scroll-behavior: smooth;
}
.cp-section {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-mute);
  padding: 12px 22px 6px;
  position: sticky; top: 0;
  background: var(--parchment-deep);
  z-index: 1;
}
.cp-empty {
  padding: 40px 0;
  text-align: center;
  color: var(--ink-mute);
  font-style: italic;
  font-family: var(--font-display);
}

.cp-item {
  width: 100%;
  display: flex; align-items: center; gap: 14px;
  padding: 11px 20px;
  background: transparent;
  border: 0;
  text-align: left;
  cursor: pointer;
  transition: background 0.1s;
  border-left: 2px solid transparent;
}
.cp-item.active {
  background: color-mix(in oklab, var(--gilt) 10%, transparent);
  border-left-color: var(--gilt);
}
.cp-item-glyph {
  width: 28px; height: 28px;
  flex-shrink: 0;
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--font-mono);
  font-size: 14px;
  color: var(--gilt-deep);
  background: color-mix(in oklab, var(--gilt) 10%, transparent);
  border: 1px solid color-mix(in oklab, var(--gilt) 30%, transparent);
  border-radius: 3px;
}
.cp-kind-saint { color: var(--rubric); border-color: color-mix(in oklab, var(--rubric) 40%, var(--hairline)); background: color-mix(in oklab, var(--rubric) 8%, transparent); }
.cp-kind-action { color: var(--lapis); border-color: color-mix(in oklab, var(--lapis) 40%, var(--hairline)); background: color-mix(in oklab, var(--lapis) 8%, transparent); }
.cp-kind-feature { color: var(--gilt-deep); }
.cp-kind-browse { color: var(--ink-soft); border-color: var(--hairline); background: transparent; }

.cp-item-text { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 1px; }
.cp-item-label {
  font-family: var(--font-display);
  font-size: 17px;
  color: var(--ink);
  line-height: 1.2;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.cp-item-sub {
  font-family: var(--font-body);
  font-size: 12px;
  font-style: italic;
  color: var(--ink-soft);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.cp-item-kind {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-mute);
  flex-shrink: 0;
  padding: 3px 7px;
  border-radius: 2px;
  border: 1px solid var(--hairline);
}
.cp-kind-tag-saint { color: var(--rubric); border-color: color-mix(in oklab, var(--rubric) 35%, var(--hairline)); }
.cp-kind-tag-view { color: var(--gilt-deep); border-color: color-mix(in oklab, var(--gilt) 40%, var(--hairline)); }
.cp-kind-tag-action { color: var(--lapis); border-color: color-mix(in oklab, var(--lapis) 35%, var(--hairline)); }

.cp-footer {
  display: flex; align-items: center; gap: 18px;
  padding: 10px 20px;
  border-top: 1px solid var(--hairline-soft);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  color: var(--ink-soft);
  background: color-mix(in oklab, var(--parchment) 50%, var(--parchment-deep));
}
.cp-footer .kbd { margin-right: 3px; }

/* Top-bar search button styled to show hint */
.nav-search-btn {
  display: inline-flex !important;
  align-items: center;
  gap: 8px !important;
}
.nav-search-hint {
  display: inline-flex; gap: 2px;
  opacity: 0.7;
}
.nav-search-hint .kbd {
  font-size: 9px;
  padding: 2px 5px;
}

@media (max-width: 720px) {
  .cp-modal { width: calc(100vw - 16px); max-height: 80vh; }
  .cp-overlay { padding-top: 8vh; }
  .nav-search-hint { display: none; }
}
