@layer components {
  /* ==========================================================================
     Command Palette — Raycast-style quick search and navigation.
     Redesigned for Cortex V2: flat panel, subtle chrome, signature pink used
     only for active selection highlights.
     ========================================================================== */

  /* Search trigger button in nav */
  .search-trigger {
    display: flex;
    align-items: center;
    gap: var(--space-2);
  }

  .search-trigger-kbd {
    display: none;
    font-family: var(--rd-font-mono);
    font-size: var(--rd-text-2xs);
    padding: 2px 5px;
    border: 1px solid var(--rd-border);
    border-radius: var(--rd-radius-sm);
    background: var(--rd-bg-sunken);
    color: var(--rd-fg-subtle);
  }

  /* Show Ctrl on non-Mac, Cmd (⌘) on Mac */
  .search-trigger-mod::before {
    content: "Ctrl+";
  }

  @supports (-webkit-touch-callout: none) {
    /* iOS */
    .search-trigger-mod::before {
      content: "⌘";
    }
  }

  @media (min-width: 768px) {
    .search-trigger-kbd {
      display: inline-flex;
      align-items: center;
      gap: 0;
    }
  }

  html.is-mac .search-trigger-mod::before {
    content: "⌘";
  }

  html:not(.is-mac) .search-trigger-mod::before {
    content: "Ctrl+";
  }

  /* ==========================================================================
     Wrapper & Backdrop
     ========================================================================== */

  .command-palette-wrapper {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding: var(--space-4);
    padding-top: 10vh;
  }

  .command-palette-backdrop {
    position: fixed;
    inset: 0;
    background: light-dark(rgba(20, 20, 28, 0.38), rgba(0, 0, 0, 0.6));
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    opacity: 0;
    transition: opacity 180ms var(--rd-ease);
  }

  .command-palette-backdrop.entering {
    opacity: 1;
  }

  /* ==========================================================================
     Panel
     ========================================================================== */

  .command-palette-panel {
    position: relative;
    width: 100%;
    max-width: 600px;
    background: var(--rd-bg-raised);
    border: 1px solid var(--rd-border);
    border-radius: var(--rd-radius-lg);
    box-shadow: var(--rd-shadow-pop);
    overflow: hidden;
    opacity: 0;
    transform: translateY(-8px) scale(0.98);
    transition:
      opacity 150ms var(--rd-ease),
      transform 150ms var(--rd-ease);
  }

  .command-palette-panel.entering {
    opacity: 1;
    transform: translateY(0) scale(1);
  }

  /* ==========================================================================
     Search Input
     ========================================================================== */

  .command-palette-search {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: 10px 14px;
    border-bottom: 1px solid var(--rd-border);
    background: var(--rd-bg-raised);
  }

  .command-palette-search-icon {
    flex-shrink: 0;
    color: var(--rd-fg-subtle);
    display: flex;
    align-items: center;
  }

  .command-palette-search form {
    flex: 1;
    display: flex;
  }

  .command-palette-input {
    flex: 1;
    border: none;
    background: transparent;
    font-family: var(--rd-font-sans);
    font-size: var(--rd-text-md);
    font-weight: 400;
    color: var(--rd-fg);
    outline: none;
    min-width: 0;
  }

  .command-palette-input::placeholder {
    color: var(--rd-fg-subtle);
  }

  .command-palette-close {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 26px;
    height: 26px;
    color: var(--rd-fg-muted);
    cursor: pointer;
    border: 1px solid var(--rd-border);
    border-radius: var(--rd-radius-sm);
    background: var(--rd-bg-sunken);
    transition:
      background var(--rd-dur-fast) var(--rd-ease),
      color var(--rd-dur-fast) var(--rd-ease),
      border-color var(--rd-dur-fast) var(--rd-ease);
  }

  .command-palette-close:hover {
    background: var(--rd-bg-hover);
    color: var(--rd-fg);
    border-color: var(--rd-border-strong);
  }

  /* ==========================================================================
     Results Area
     ========================================================================== */

  .command-palette-results {
    max-height: 420px;
    overflow-y: auto;
    padding: var(--rd-sp-2) 0;
    background: var(--rd-bg-raised);
  }

  .command-palette-results::-webkit-scrollbar {
    width: 6px;
  }

  .command-palette-results::-webkit-scrollbar-track {
    background: transparent;
  }

  .command-palette-results::-webkit-scrollbar-thumb {
    background: var(--rd-border);
    border-radius: 3px;
  }

  .command-palette-results::-webkit-scrollbar-thumb:hover {
    background: var(--rd-border-strong);
  }

  .command-palette-list {
    list-style: none;
    margin: 0;
    padding: 0;
  }

  /* ==========================================================================
     Result Items
     ========================================================================== */

  .command-palette-item {
    display: block;
    margin: 0 var(--rd-sp-2);
    padding: 0;
    cursor: pointer;
    border-radius: var(--rd-radius-md);
    transition: background var(--rd-dur-fast) var(--rd-ease);
  }

  .command-palette-item:hover {
    background: var(--rd-bg-hover);
    outline: none;
  }

  .command-palette-item:focus,
  .command-palette-item[aria-selected="true"] {
    background: var(--rd-accent-soft);
    outline: none;
  }

  .command-palette-item[aria-selected="true"] .command-palette-item-title {
    color: var(--rd-accent);
  }

  .command-palette-item-link {
    display: flex;
    align-items: center;
    gap: var(--rd-sp-3);
    padding: 8px 10px;
    text-decoration: none;
    color: inherit;
    border-radius: inherit;
  }

  .command-palette-item-icon {
    flex-shrink: 0;
    width: 28px;
    height: 28px;
    display: grid;
    place-items: center;
    background: var(--rd-bg-sunken);
    border: 1px solid var(--rd-border);
    border-radius: var(--rd-radius-md);
    color: var(--rd-fg-muted);
  }

  /* Subtle tinted variants — no heavy saturated fills. */
  .command-palette-item-icon.icon-project {
    background: var(--rd-info-soft);
    border-color: transparent;
    color: var(--rd-info);
  }

  .command-palette-item-icon.icon-client {
    background: var(--rd-success-soft);
    border-color: transparent;
    color: var(--rd-success);
  }

  .command-palette-item-icon.icon-team {
    background: var(--rd-accent-soft);
    border-color: transparent;
    color: var(--rd-accent);
  }

  .command-palette-item-icon.icon-invoice {
    background: var(--rd-warn-soft);
    border-color: transparent;
    color: var(--rd-warn);
  }

  .command-palette-item-icon.icon-action {
    background: var(--rd-accent-soft);
    border-color: transparent;
    color: var(--rd-accent);
  }

  .command-palette-item-icon.icon-nav {
    background: var(--rd-bg-sunken);
    border-color: var(--rd-border);
    color: var(--rd-fg-muted);
  }

  .command-palette-item-content {
    flex: 1;
    min-width: 0;
  }

  .command-palette-item-title {
    font-family: var(--rd-font-sans);
    font-size: var(--rd-text-base);
    font-weight: 500;
    color: var(--rd-fg);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .command-palette-item-subtitle {
    font-size: var(--rd-text-xs);
    color: var(--rd-fg-subtle);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-top: 1px;
  }

  .command-palette-item-meta {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    gap: var(--rd-sp-2);
  }

  .command-palette-item-shortcut {
    font-family: var(--rd-font-mono);
    font-size: var(--rd-text-2xs);
    padding: 2px 6px;
    background: var(--rd-bg-sunken);
    border: 1px solid var(--rd-border);
    border-radius: var(--rd-radius-sm);
    color: var(--rd-fg-subtle);
  }

  .command-palette-item-badge {
    font-size: var(--rd-text-2xs);
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    padding: 2px 7px;
    border-radius: var(--rd-radius-full);
    background: var(--rd-bg-sunken);
    border: 1px solid var(--rd-border);
    color: var(--rd-fg-muted);
  }

  .command-palette-item-badge.badge-active,
  .command-palette-item-badge.badge-paid {
    background: var(--rd-success-soft);
    border-color: transparent;
    color: var(--rd-success);
  }

  .command-palette-item-badge.badge-draft,
  .command-palette-item-badge.badge-forecast,
  .command-palette-item-badge.badge-scheduled {
    background: var(--rd-warn-soft);
    border-color: transparent;
    color: var(--rd-warn);
  }

  .command-palette-item-badge.badge-sent,
  .command-palette-item-badge.badge-approved {
    background: var(--rd-info-soft);
    border-color: transparent;
    color: var(--rd-info);
  }

  .command-palette-item-type {
    font-size: var(--rd-text-2xs);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--rd-fg-subtle);
  }

  /* ==========================================================================
     Search Highlighting
     ========================================================================== */

  .command-palette-highlight {
    background: var(--rd-accent-soft);
    color: var(--rd-accent);
    padding: 0 2px;
    font-weight: 600;
    border-radius: 2px;
  }

  /* ==========================================================================
     Empty & No Results States
     ========================================================================== */

  .command-palette-empty {
    padding: 48px 20px;
    text-align: center;
    color: var(--rd-fg-muted);
  }

  .command-palette-empty-icon {
    display: inline-grid;
    place-items: center;
    width: 44px;
    height: 44px;
    margin-bottom: var(--rd-sp-4);
    background: var(--rd-bg-sunken);
    border: 1px solid var(--rd-border);
    border-radius: var(--rd-radius-full);
    color: var(--rd-fg-subtle);
  }

  .command-palette-empty-title {
    font-family: var(--rd-font-sans);
    font-size: var(--rd-text-md);
    font-weight: 600;
    color: var(--rd-fg);
    margin-bottom: var(--rd-sp-1);
  }

  .command-palette-empty-hint {
    font-size: var(--rd-text-sm);
    color: var(--rd-fg-muted);
    line-height: 1.5;
  }

  .command-palette-empty-hint kbd {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 20px;
    height: 20px;
    padding: 0 5px;
    margin: 0 2px;
    font-family: var(--rd-font-mono);
    font-size: var(--rd-text-2xs);
    font-weight: 500;
    border: 1px solid var(--rd-border);
    border-radius: var(--rd-radius-sm);
    background: var(--rd-bg-sunken);
    color: var(--rd-fg-muted);
  }

  /* ==========================================================================
     Footer
     ========================================================================== */

  .command-palette-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 8px 14px;
    border-top: 1px solid var(--rd-border);
    font-size: var(--rd-text-xs);
    color: var(--rd-fg-subtle);
    background: var(--rd-bg-sunken);
  }

  .command-palette-footer-section {
    display: flex;
    align-items: center;
    gap: var(--rd-sp-3);
  }

  .command-palette-footer kbd {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 18px;
    height: 18px;
    padding: 0 4px;
    font-family: var(--rd-font-mono);
    font-size: var(--rd-text-2xs);
    border: 1px solid var(--rd-border);
    border-radius: var(--rd-radius-sm);
    background: var(--rd-bg-raised);
    color: var(--rd-fg-muted);
  }

  .command-palette-footer-hint {
    display: flex;
    align-items: center;
    gap: 3px;
  }

  /* ==========================================================================
     Section Dividers
     ========================================================================== */

  .command-palette-divider {
    height: 1px;
    background: var(--rd-border);
    margin: var(--rd-sp-2) var(--rd-sp-3);
  }

  .command-palette-section-label {
    padding: var(--rd-sp-2) 16px var(--rd-sp-1);
    font-family: var(--rd-font-sans);
    font-size: var(--rd-text-2xs);
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--rd-fg-subtle);
  }
}
