/*
 * Custom Field Input Styles
 *
 * Shared styles for the custom-field input partials
 * (app/views/custom_fields/inputs/*).
 *
 * These used to live as inline <style> blocks inside each partial, which
 * placed them in the implicit "unlayered" cascade tier and made them beat
 * any @layer rules regardless of specificity. Moving them into an explicit
 * @layer components block lets consumer styles (e.g. the redesign's
 * .wi-fields-input-field overrides) win via normal specificity rules.
 */

@layer components {
  /* ==========================================================================
     Boolean toggle (Yes/No radio group)
     ========================================================================== */

  .toggle-group {
    display: flex;
    gap: var(--space-2);
  }

  .toggle-option {
    display: flex;
    align-items: center;
    gap: var(--space-1);
    padding: var(--space-2) var(--space-3);
    border: 1px solid var(--color-border);
    cursor: pointer;
    transition: all 0.15s ease;
  }

  .toggle-option:hover {
    background: var(--color-surface-hover);
  }

  .toggle-option:has(input:checked) {
    border-color: var(--color-primary);
    background: color-mix(in oklch, var(--color-primary) 10%, var(--color-surface));
  }

  .toggle-option input {
    margin: 0;
  }

  /* ==========================================================================
     Multi-select typeahead picker
     ========================================================================== */

  .multi-select-field {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
  }

  /* Selected tags */
  .multi-select-selected {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
    min-height: 32px;
    align-items: center;
  }

  .multi-select-tag {
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
    padding: var(--space-1) var(--space-2);
    background: var(--rd-accent);
    color: white;
    border: 1px solid var(--color-border);
    font-size: var(--text-sm);
  }

  .multi-select-tag-name {
    font-weight: var(--font-medium);
  }

  .multi-select-tag-remove {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    padding: 0;
    margin: 0;
    background: none;
    border: none;
    color: white;
    font-size: var(--text-base);
    line-height: 1;
    cursor: pointer;
    transition: background-color 0.15s, color 0.15s;
  }

  .multi-select-tag-remove:hover {
    background: var(--color-negative);
    color: white;
  }

  .multi-select-none {
    color: var(--color-ink-muted);
    font-style: italic;
  }

  /* Search input wrapper */
  .multi-select-search-wrapper {
    position: relative;
  }

  .multi-select-search {
    width: 100%;
  }

  /* Dropdown - Pop Art style */
  .multi-select-dropdown {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    z-index: 100;
    max-height: 250px;
    overflow-y: auto;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    box-shadow: var(--rd-shadow-sm, 0 1px 3px rgb(0 0 0 / 0.1));
    margin-top: var(--space-1);
  }

  .multi-select-dropdown-item {
    display: block;
    width: 100%;
    padding: var(--space-2) var(--space-3);
    background: none;
    border: none;
    text-align: left;
    cursor: pointer;
    font-weight: var(--font-medium);
    color: var(--color-ink);
    transition: background-color 0.15s;
  }

  .multi-select-dropdown-item:hover {
    background: var(--color-surface-raised);
  }

  .multi-select-dropdown-item:focus {
    outline: none;
    background: var(--color-info-canvas);
  }

  .multi-select-dropdown-empty {
    padding: var(--space-3);
    text-align: center;
    color: var(--color-ink-muted);
    font-style: italic;
  }
}
