/*
  MFP Design System — Select
  Production CSS for select component.
  Import tokens.css before this file.
*/

/* ======================================================================
   SELECT
   ====================================================================== */
.select-wrap {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  min-width: 220px;
}
.select-container {
  position: relative;
}
.select {
  display: flex;
  align-items: center;
  height: 44px;
  padding: 0 12px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-medium-grey);
  background: var(--color-white);
  cursor: pointer;
  user-select: none;
  gap: var(--space-8);
}
.select__value {
  flex: 1;
  font: var(--type-input-label);
  color: var(--color-darkest-grey);
}
.select__placeholder {
  flex: 1;
  font: var(--type-input-label);
  color: var(--color-dark-grey);
}
.select__chevron {
  font-size: 24px;
  color: var(--color-darker-grey);
  pointer-events: none;
}
.select-hint {
  font: var(--type-body-small);
  color: var(--color-dark-grey);
}
.select--hover   { border: 2px solid var(--color-action); padding: 0 11px; }
.select:not(.select--disabled):not(.select--expand):hover { border: 2px solid var(--color-action); padding: 0 11px; }
.select--prefilled { border: 1px solid var(--color-dark-grey); }
.select--selected { border: 1px solid var(--color-action); }
.select--expand  { border: 2px solid var(--color-action); padding: 0 11px; }
.select--disabled {
  background: var(--color-light-grey);
  border: 1px solid var(--color-medium-grey);
  cursor: not-allowed;
}
.select--disabled .select__value,
.select--disabled .select__placeholder,
.select--disabled .select__chevron { color: var(--color-medium-grey); }
.select--error   { border: 2px solid var(--color-danger);    padding: 0 11px; }
.select--success { border: 2px solid var(--color-green-700); padding: 0 11px; }
.select-hint--error   { color: var(--color-danger); }
.select-hint--success { color: var(--color-green-700); }

.select-menu {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  right: 0;
  background: var(--color-white);
  box-shadow: var(--shadow-2);
  border-radius: var(--radius-sm);
  padding: 4px 0;
  z-index: 100;
}
.select-menu__item {
  display: flex;
  align-items: center;
  gap: var(--space-12);
  height: 38px;
  padding: 0 12px;
  cursor: pointer;
  font: var(--type-input-label);
  color: var(--color-darkest-grey);
  transition: background 100ms;
}
.select-menu__item:hover,
.select-menu__item--active {
  background: var(--color-pale-grey);
  color: var(--color-darkest-grey);
}
.select-menu__icon {
  font-size: 20px;
  color: var(--color-action);
  font-variation-settings: 'FILL' 1, 'wght' 400, 'GRAD' 0, 'opsz' 20;
}

/* ======================================================================
   SLIM
   ====================================================================== */
.select--sm {
  height: 32px;
}

.select--sm .select__value,
.select--sm .select__placeholder {
  font: var(--type-input-label-sm);
}

.select--sm .select__chevron {
  font-size: 20px;
}
