/* =============================================================================
   LINGUA LP — PRIMITIVES UI
   -----------------------------------------------------------------------------
   Les briques réutilisables. Elles NE référencent QUE des tokens (tokens.css).
   Aucune valeur en dur ici → cohérence garantie, thème changeable d'un coup.
   Une brique = un seul endroit, déclinée par variantes (classes --modifier).
   ========================================================================== */

*, *::before, *::after { box-sizing: border-box; }

body {
  margin: 0;
  font-family: var(--font-sans);
  font-size: var(--text-md);
  line-height: var(--leading-normal);
  color: var(--color-text);
  background: var(--color-background);
}

/* --- Button ------------------------------------------------------------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--space-2);
  font-family: inherit; font-size: var(--text-sm); font-weight: var(--font-semibold);
  line-height: 1; white-space: nowrap;
  padding: var(--space-3) var(--space-4);
  border: 1px solid transparent; border-radius: var(--radius-sm);
  cursor: pointer; transition: background var(--dur-fast) var(--ease), border-color var(--dur-fast) var(--ease);
}
.btn:focus-visible { outline: 2px solid var(--color-primary); outline-offset: 2px; }
.btn:disabled, .btn[aria-disabled="true"] { opacity: .5; cursor: not-allowed; }

.btn--primary   { background: var(--color-primary); color: var(--color-text-on-primary); }
.btn--primary:hover:not(:disabled)   { background: var(--color-primary-hover); }
.btn--secondary { background: var(--color-surface); color: var(--color-text-strong); border-color: var(--color-border); }
.btn--secondary:hover:not(:disabled) { background: var(--color-surface-alt); }
.btn--ghost     { background: transparent; color: var(--color-text); }
.btn--ghost:hover:not(:disabled)     { background: var(--color-surface-alt); }
.btn--danger    { background: var(--color-danger); color: #fff; }
.btn--danger:hover:not(:disabled)    { filter: brightness(.94); }

.btn--sm { padding: var(--space-2) var(--space-3); font-size: var(--text-xs); }
.btn--lg { padding: var(--space-4) var(--space-5); font-size: var(--text-md); }

.btn--loading { position: relative; color: transparent !important; }
.btn--loading::after {
  content: ""; position: absolute; width: 1em; height: 1em; border-radius: var(--radius-full);
  border: 2px solid currentColor; border-top-color: transparent;
  animation: spin .7s linear infinite; color: var(--color-text-on-primary);
}

/* --- IconButton (bouton icône, réutilisable partout) -------------------- */
.icon-btn {
  display: inline-flex; align-items: center; justify-content: center;
  width: 34px; height: 34px; padding: 0; font-size: 16px; line-height: 1;
  border: 1px solid transparent; border-radius: var(--radius-sm);
  background: transparent; color: var(--color-text); cursor: pointer;
  transition: background var(--dur-fast) var(--ease), border-color var(--dur-fast) var(--ease);
}
.icon-btn:hover { background: var(--color-surface-alt); }
.icon-btn:focus-visible { outline: 2px solid var(--color-primary); outline-offset: 2px; }
.icon-btn--active   { background: var(--color-primary-soft); border-color: var(--color-primary); color: var(--color-primary); }
.icon-btn--bordered { border-color: var(--color-border); background: var(--color-surface); }
.icon-btn--sm { width: 28px; height: 28px; font-size: 14px; }
.icon-btn--lg { width: 42px; height: 42px; font-size: 18px; }
.icon-btn--danger:hover { background: var(--color-danger-soft); color: var(--color-danger); } /* ex. poubelle */

/* --- Link --------------------------------------------------------------- */
.link { color: var(--color-text-link); text-decoration: none; font-weight: var(--font-medium); }
.link:hover { text-decoration: underline; }

/* --- Field + contrôles -------------------------------------------------- */
.field { display: flex; flex-direction: column; gap: var(--space-2); }
.field__label { font-size: var(--text-sm); font-weight: var(--font-medium); color: var(--color-text-strong); }
.field__hint  { font-size: var(--text-xs); color: var(--color-text-muted); }
.field__error { font-size: var(--text-xs); color: var(--color-danger); }

.input, .textarea, .select {
  font-family: inherit; font-size: var(--text-sm); color: var(--color-text-strong);
  background: var(--color-surface); border: 1px solid var(--color-border);
  border-radius: var(--radius-sm); padding: var(--space-3) var(--space-3); width: 100%;
  transition: border-color var(--dur-fast) var(--ease), box-shadow var(--dur-fast) var(--ease);
}
.input:focus, .textarea:focus, .select:focus {
  outline: none; border-color: var(--color-primary);
  box-shadow: 0 0 0 3px var(--color-primary-soft);
}
.field--error .input, .field--error .textarea { border-color: var(--color-danger); }
.input::placeholder { color: var(--color-text-muted); }

/* --- Toast -------------------------------------------------------------- */
.toast {
  display: flex; align-items: flex-start; gap: var(--space-3);
  background: var(--color-surface); border: 1px solid var(--color-border);
  border-left: 4px solid var(--color-info);
  border-radius: var(--radius-md); padding: var(--space-3) var(--space-4);
  box-shadow: var(--shadow-md); max-width: 380px;
}
.toast__title { font-weight: var(--font-semibold); color: var(--color-text-strong); font-size: var(--text-sm); }
.toast__body  { font-size: var(--text-sm); color: var(--color-text-muted); }
/* fond doux teinté (token -soft) + liséré gauche fort CONSERVÉ (déclaré après le
   fond pour ne pas être écrasé) */
.toast--success { background: var(--color-success-soft); border-left-color: var(--color-success); }
.toast--warning { background: var(--color-warning-soft); border-left-color: var(--color-warning); }
.toast--danger  { background: var(--color-danger-soft);  border-left-color: var(--color-danger); }
.toast--info    { background: var(--color-info-soft);    border-left-color: var(--color-info); }

/* --- Alert (inline) ----------------------------------------------------- */
.alert { border-radius: var(--radius-md); padding: var(--space-3) var(--space-4); font-size: var(--text-sm); }
.alert--success { background: var(--color-success-soft); color: var(--color-success); }
.alert--warning { background: var(--color-warning-soft); color: var(--color-warning); }
.alert--danger  { background: var(--color-danger-soft);  color: var(--color-danger); }
.alert--info    { background: var(--color-info-soft);    color: var(--color-info); }

/* --- Badge / Tag -------------------------------------------------------- */
.badge {
  display: inline-flex; align-items: center; gap: var(--space-1);
  font-size: var(--text-xs); font-weight: var(--font-semibold);
  padding: 2px var(--space-2); border-radius: var(--radius-full);
  background: var(--color-surface-alt); color: var(--color-text);
}
.badge--success { background: var(--color-success-soft); color: var(--color-success); }
.badge--warning { background: var(--color-warning-soft); color: var(--color-warning); }
.badge--danger  { background: var(--color-danger-soft);  color: var(--color-danger); }
.badge--info    { background: var(--color-info-soft);    color: var(--color-info); }
.badge--primary { background: var(--color-primary-soft); color: var(--color-primary); }
.badge--secondary { background: var(--color-secondary-soft); color: var(--color-secondary-hover); }

/* --- Card --------------------------------------------------------------- */
.card {
  background: var(--color-surface); border: 1px solid var(--color-border);
  border-radius: var(--radius-lg); box-shadow: var(--shadow-sm);
}
.card__header { padding: var(--space-4) var(--space-5); border-bottom: 1px solid var(--color-border);
  font-weight: var(--font-semibold); color: var(--color-text-strong); }
.card__body   { padding: var(--space-5); }

/* --- Avatar ------------------------------------------------------------- */
.avatar {
  display: inline-flex; align-items: center; justify-content: center;
  width: 36px; height: 36px; border-radius: var(--radius-full);
  background: var(--color-primary-soft); color: var(--color-primary);
  font-size: var(--text-sm); font-weight: var(--font-semibold);
}

/* --- Spinner ------------------------------------------------------------ */
.spinner {
  display: inline-block; width: 1.25em; height: 1.25em; border-radius: var(--radius-full);
  border: 2px solid var(--color-border); border-top-color: var(--color-primary);
  animation: spin .7s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* --- Table -------------------------------------------------------------- */
.table { width: 100%; border-collapse: collapse; font-size: var(--text-sm); }
.table th { text-align: left; color: var(--color-text-muted); font-weight: var(--font-medium);
  padding: var(--space-2) var(--space-3); border-bottom: 1px solid var(--color-border); }
.table td { padding: var(--space-3); border-bottom: 1px solid var(--color-border); color: var(--color-text); }
.table tr:hover td { background: var(--color-surface-alt); }

/* --- Checkbox / Radio (natifs, teintés) --------------------------------- */
.check { display: inline-flex; align-items: center; gap: var(--space-2); font-size: var(--text-sm); color: var(--color-text); cursor: pointer; }
.check input[type="checkbox"], .check input[type="radio"] { accent-color: var(--color-primary); width: 16px; height: 16px; margin: 0; }

/* --- Switch (interrupteur) ---------------------------------------------- */
.switch { display: inline-flex; align-items: center; gap: var(--space-2); cursor: pointer; }
.switch input { position: absolute; opacity: 0; width: 0; height: 0; }
.switch__track { width: 38px; height: 22px; border-radius: var(--radius-full); background: var(--color-border);
  transition: background var(--dur-fast) var(--ease); position: relative; flex-shrink: 0; }
.switch__track::after { content: ""; position: absolute; top: 2px; left: 2px; width: 18px; height: 18px;
  border-radius: var(--radius-full); background: #fff; box-shadow: var(--shadow-sm); transition: transform var(--dur-fast) var(--ease); }
.switch input:checked + .switch__track { background: var(--color-primary); }
.switch input:checked + .switch__track::after { transform: translateX(16px); }
.switch input:focus-visible + .switch__track { outline: 2px solid var(--color-primary); outline-offset: 2px; }

/* --- Modal / Dialog ----------------------------------------------------- */
.overlay { position: fixed; inset: 0; background: var(--color-overlay); z-index: var(--z-modal);
  display: flex; align-items: center; justify-content: center; padding: var(--space-4); }
.modal { background: var(--color-surface); border-radius: var(--radius-lg); box-shadow: var(--shadow-lg);
  width: 100%; max-width: 480px; }
/* pas d'overflow:hidden : les info-bulles / menus doivent pouvoir déborder de la modale */
.modal--sm { max-width: 380px; }
.modal--lg { max-width: 720px; }
.modal__header { position: relative; padding: var(--space-4) var(--space-7); border-bottom: 1px solid var(--color-border);
  font-weight: var(--font-semibold); color: var(--color-text-strong); text-align: center; }
.modal__header .icon-btn { position: absolute; right: var(--space-3); top: 50%; transform: translateY(-50%);
  color: var(--color-text-muted); border-radius: var(--radius-full); }
.modal__header .icon-btn:hover { color: var(--color-text-strong); background: var(--color-surface-alt); }
.modal__body { padding: var(--space-5); color: var(--color-text); }
.modal__footer { padding: var(--space-4) var(--space-5); border-top: 1px solid var(--color-border);
  display: flex; justify-content: flex-end; gap: var(--space-2); }

/* --- Dropdown / Menu ---------------------------------------------------- */
.menu { min-width: 200px; background: var(--color-surface); border: 1px solid var(--color-border);
  border-radius: var(--radius-md); box-shadow: var(--shadow-md); padding: var(--space-1); z-index: var(--z-dropdown); }
.menu__item { display: flex; align-items: center; gap: var(--space-2); padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm); font-size: var(--text-sm); color: var(--color-text); cursor: pointer; }
.menu__item:hover { background: var(--color-surface-alt); }
.menu__item--danger { color: var(--color-danger); }
.menu__item--danger:hover { background: var(--color-danger-soft); }
.menu__item[aria-disabled="true"] { opacity: .5; cursor: not-allowed; }
.menu__sep { height: 1px; background: var(--color-border); margin: var(--space-1) 0; }

/* --- Tabs --------------------------------------------------------------- */
.tabs { display: flex; gap: var(--space-2); border-bottom: 1px solid var(--color-border); }
.tab { padding: var(--space-3); font-size: var(--text-sm); font-weight: var(--font-medium); color: var(--color-text-muted);
  background: none; border: none; border-bottom: 2px solid transparent; margin-bottom: -1px; cursor: pointer; }
.tab:hover { color: var(--color-text); }
.tab--active { color: var(--color-primary); border-bottom-color: var(--color-primary); }

/* --- Pagination --------------------------------------------------------- */
.pagination { display: inline-flex; align-items: center; gap: var(--space-1); }
.pagination__item { min-width: 32px; height: 32px; display: inline-flex; align-items: center; justify-content: center;
  padding: 0 var(--space-2); border: 1px solid var(--color-border); border-radius: var(--radius-sm);
  background: var(--color-surface); color: var(--color-text); font-size: var(--text-sm); cursor: pointer; }
.pagination__item:hover { background: var(--color-surface-alt); }
.pagination__item--active { background: var(--color-primary); color: var(--color-primary-contrast); border-color: var(--color-primary); }
.pagination__item[aria-disabled="true"] { opacity: .5; cursor: not-allowed; }

/* --- Tooltip (CSS, via data-tip) ---------------------------------------- */
.tip { position: relative; }
/* par défaut EN DESSOUS (évite la coupe dans les barres du haut) */
.tip::after { content: attr(data-tip); position: absolute; top: 100%; left: 50%; transform: translate(-50%, 6px);
  background: var(--color-text-strong); color: #fff; font-size: var(--text-xs); padding: 2px var(--space-2);
  border-radius: var(--radius-sm); white-space: nowrap; opacity: 0; pointer-events: none;
  transition: opacity var(--dur-fast) var(--ease); z-index: var(--z-toast); }
.tip--top::after { top: auto; bottom: 100%; transform: translate(-50%, -6px); } /* pour un élément près du bas */
.tip:hover::after, .tip:focus-visible::after { opacity: 1; }

/* --- Icon (référence le sprite design/icons.svg ; couleur via currentColor) */
.icon { width: 1.25em; height: 1.25em; display: inline-block; vertical-align: -0.15em;
  fill: none; stroke: currentColor; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.icon--sm { width: 1em; height: 1em; }
.icon--lg { width: 1.5em; height: 1.5em; }
