/* components.css — Composants UI réutilisables Victoria.app (PR#10)
 *
 * Couche 3 du design system (tokens.css couches 1-2 → components.css couche 3).
 * Préfixe `.vic-` (Victoria Components) — distinct du préfixe `.vc-` spécifique au chat.
 *
 * Composants :
 *   - Boutons     : .vic-btn + variants (--primary, --secondary, --ghost, --danger, --icon)
 *   - Modales     : .vic-modal-backdrop + .vic-modal (header, body, footer)
 *   - Toasts      : .vic-toaster + .vic-toast + variants (--success, --warning, --error, --info)
 *   - Skeleton    : .vic-skeleton + variants (--text, --circle, --block)
 */

/* ════════════════════════════════════════════════════════════════════════
   BOUTONS
   ════════════════════════════════════════════════════════════════════════ */

.vic-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--vic-space-2);
  padding: var(--vic-space-2) var(--vic-space-4);
  min-height: 36px;
  border-radius: var(--vic-radius-md);
  border: 1px solid transparent;
  font-family: var(--vic-font-body);
  font-size: var(--vic-text-sm);
  font-weight: var(--vic-weight-medium);
  line-height: var(--vic-leading-tight);
  white-space: nowrap;
  cursor: pointer;
  transition:
    background var(--vic-duration-fast) var(--vic-ease-standard),
    color var(--vic-duration-fast) var(--vic-ease-standard),
    border-color var(--vic-duration-fast) var(--vic-ease-standard),
    box-shadow var(--vic-duration-fast) var(--vic-ease-standard),
    opacity var(--vic-duration-fast) var(--vic-ease-standard);
  text-decoration: none;
  user-select: none;
}

.vic-btn:focus-visible {
  outline: none;
  box-shadow: var(--vic-focus-ring);
}

.vic-btn:disabled,
.vic-btn[aria-disabled="true"] {
  opacity: 0.45;
  cursor: not-allowed;
  pointer-events: none;
}

/* Tailles */
.vic-btn--sm {
  padding: var(--vic-space-1) var(--vic-space-3);
  min-height: 28px;
  font-size: var(--vic-text-xs);
  border-radius: var(--vic-radius-sm);
}

.vic-btn--lg {
  padding: var(--vic-space-3) var(--vic-space-6);
  min-height: 44px;
  font-size: var(--vic-text-base);
  border-radius: var(--vic-radius-lg);
}

/* Bouton icône seul */
.vic-btn--icon {
  padding: var(--vic-space-2);
  min-height: 36px;
  min-width: 36px;
  border-radius: var(--vic-radius-md);
}
.vic-btn--icon.vic-btn--sm { min-height: 28px; min-width: 28px; padding: var(--vic-space-1); }
.vic-btn--icon.vic-btn--lg { min-height: 44px; min-width: 44px; padding: var(--vic-space-3); }

/* Variant : primary (gold) */
.vic-btn--primary {
  background: var(--vic-color-accent);
  color: var(--vic-color-text-on-accent);
  border-color: var(--vic-color-accent);
}
.vic-btn--primary:hover:not(:disabled):not([aria-disabled="true"]) {
  background: var(--vic-color-accent-hover);
  border-color: var(--vic-color-accent-hover);
}
.vic-btn--primary:active:not(:disabled) {
  background: var(--vic-gold-500);
  border-color: var(--vic-gold-500);
}

/* Variant : secondary (outlined) */
.vic-btn--secondary {
  background: transparent;
  color: var(--vic-color-text);
  border-color: var(--vic-color-border-strong);
}
.vic-btn--secondary:hover:not(:disabled):not([aria-disabled="true"]) {
  background: var(--vic-color-bg-raised);
  border-color: var(--vic-color-accent);
  color: var(--vic-color-accent);
}
.vic-btn--secondary:active:not(:disabled) {
  background: var(--vic-color-bg-overlay);
}

/* Variant : ghost */
.vic-btn--ghost {
  background: transparent;
  color: var(--vic-color-text-muted);
  border-color: transparent;
}
.vic-btn--ghost:hover:not(:disabled):not([aria-disabled="true"]) {
  background: var(--vic-color-bg-raised);
  color: var(--vic-color-text);
}
.vic-btn--ghost:active:not(:disabled) {
  background: var(--vic-color-bg-overlay);
}

/* Variant : danger */
.vic-btn--danger {
  background: transparent;
  color: var(--vic-color-danger);
  border-color: var(--vic-color-danger);
}
.vic-btn--danger:hover:not(:disabled):not([aria-disabled="true"]) {
  background: rgba(196, 43, 43, 0.12);
}
.vic-btn--danger:active:not(:disabled) {
  background: rgba(196, 43, 43, 0.20);
}

/* Variant : accent-ghost (ghost teinté gold) */
.vic-btn--accent-ghost {
  background: var(--vic-color-accent-muted);
  color: var(--vic-color-accent-strong);
  border-color: transparent;
}
.vic-btn--accent-ghost:hover:not(:disabled):not([aria-disabled="true"]) {
  background: var(--vic-color-accent);
  color: var(--vic-color-text-on-accent);
}

/* Groupe de boutons */
.vic-btn-group {
  display: inline-flex;
  gap: 0;
}
.vic-btn-group .vic-btn { border-radius: 0; }
.vic-btn-group .vic-btn:first-child { border-radius: var(--vic-radius-md) 0 0 var(--vic-radius-md); }
.vic-btn-group .vic-btn:last-child  { border-radius: 0 var(--vic-radius-md) var(--vic-radius-md) 0; }
.vic-btn-group .vic-btn + .vic-btn  { margin-left: -1px; }

/* État loading */
.vic-btn.is-loading {
  pointer-events: none;
  position: relative;
  color: transparent;
}
.vic-btn.is-loading::after {
  content: '';
  position: absolute;
  width: 14px;
  height: 14px;
  border: 2px solid currentColor;
  border-top-color: transparent;
  border-radius: 50%;
  animation: vic-spin var(--vic-duration-slow) linear infinite;
  color: inherit;
  /* restaurer la couleur du texte pour le spinner */
  border-color: rgba(255, 255, 255, 0.4);
  border-top-color: rgba(255, 255, 255, 0.9);
}
.vic-btn--primary.is-loading::after {
  border-color: rgba(12, 11, 9, 0.3);
  border-top-color: rgba(12, 11, 9, 0.9);
}

@keyframes vic-spin {
  to { transform: rotate(360deg); }
}


/* ════════════════════════════════════════════════════════════════════════
   MODALES
   ════════════════════════════════════════════════════════════════════════ */

.vic-modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.65);
  backdrop-filter: blur(2px);
  z-index: var(--vic-z-modal);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--vic-space-4);
  animation: vic-backdrop-in var(--vic-duration-base) var(--vic-ease-out) both;
}

.vic-modal-backdrop.is-closing {
  animation: vic-backdrop-out var(--vic-duration-fast) var(--vic-ease-in) both;
}

@keyframes vic-backdrop-in {
  from { opacity: 0; }
  to   { opacity: 1; }
}
@keyframes vic-backdrop-out {
  from { opacity: 1; }
  to   { opacity: 0; }
}

.vic-modal {
  position: relative;
  background: var(--vic-color-bg-alt);
  border: 1px solid var(--vic-color-border-strong);
  border-radius: var(--vic-radius-xl);
  box-shadow: var(--vic-shadow-lg);
  width: 100%;
  max-width: 520px;
  max-height: calc(100dvh - var(--vic-space-8));
  display: flex;
  flex-direction: column;
  animation: vic-modal-in var(--vic-duration-base) var(--vic-ease-out) both;
}

.vic-modal-backdrop.is-closing .vic-modal {
  animation: vic-modal-out var(--vic-duration-fast) var(--vic-ease-in) both;
}

@keyframes vic-modal-in {
  from { opacity: 0; transform: translateY(12px) scale(0.97); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}
@keyframes vic-modal-out {
  from { opacity: 1; transform: translateY(0) scale(1); }
  to   { opacity: 0; transform: translateY(8px) scale(0.97); }
}

/* Tailles de modal */
.vic-modal--sm  { max-width: 360px; }
.vic-modal--lg  { max-width: 720px; }
.vic-modal--xl  { max-width: 960px; }
.vic-modal--full { max-width: calc(100vw - var(--vic-space-8)); }

.vic-modal__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--vic-space-3);
  padding: var(--vic-space-5) var(--vic-space-6);
  border-bottom: 1px solid var(--vic-color-border);
  flex-shrink: 0;
}

.vic-modal__title {
  font-family: var(--vic-font-display);
  font-size: var(--vic-text-lg);
  font-weight: var(--vic-weight-medium);
  color: var(--vic-color-text);
  letter-spacing: var(--vic-tracking-tight);
  line-height: var(--vic-leading-snug);
}

.vic-modal__close {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  flex-shrink: 0;
  background: transparent;
  border: none;
  color: var(--vic-color-text-muted);
  cursor: pointer;
  border-radius: var(--vic-radius-sm);
  transition: color var(--vic-duration-fast) var(--vic-ease-standard),
              background var(--vic-duration-fast) var(--vic-ease-standard);
  font-size: 1.1rem;
  line-height: 1;
}
.vic-modal__close:hover {
  color: var(--vic-color-text);
  background: var(--vic-color-bg-raised);
}
.vic-modal__close:focus-visible {
  outline: none;
  box-shadow: var(--vic-focus-ring);
}

.vic-modal__body {
  padding: var(--vic-space-5) var(--vic-space-6);
  overflow-y: auto;
  flex: 1;
  color: var(--vic-color-text);
  font-size: var(--vic-text-base);
  line-height: var(--vic-leading-normal);
}

.vic-modal__footer {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--vic-space-3);
  padding: var(--vic-space-4) var(--vic-space-6);
  border-top: 1px solid var(--vic-color-border);
  flex-shrink: 0;
  flex-wrap: wrap;
}

.vic-modal__footer--left {
  justify-content: flex-start;
}
.vic-modal__footer--spread {
  justify-content: space-between;
}

@media (max-width: 480px) {
  .vic-modal {
    border-radius: var(--vic-radius-lg) var(--vic-radius-lg) 0 0;
    max-height: 90dvh;
    align-self: flex-end;
    margin-bottom: 0;
  }
  .vic-modal-backdrop { align-items: flex-end; padding: 0; }
  @keyframes vic-modal-in {
    from { opacity: 0; transform: translateY(100%); }
    to   { opacity: 1; transform: translateY(0); }
  }
}


/* ════════════════════════════════════════════════════════════════════════
   TOASTS
   ════════════════════════════════════════════════════════════════════════ */

.vic-toaster {
  position: fixed;
  top: var(--vic-space-4);
  right: var(--vic-space-4);
  z-index: var(--vic-z-toast);
  display: flex;
  flex-direction: column;
  gap: var(--vic-space-2);
  max-width: min(360px, calc(100vw - var(--vic-space-8)));
  pointer-events: none;
}

.vic-toast {
  display: flex;
  align-items: flex-start;
  gap: var(--vic-space-3);
  padding: var(--vic-space-3) var(--vic-space-4);
  background: var(--vic-color-bg-overlay);
  border: 1px solid var(--vic-color-border-strong);
  border-radius: var(--vic-radius-lg);
  box-shadow: var(--vic-shadow-md);
  pointer-events: auto;
  animation: vic-toast-in var(--vic-duration-base) var(--vic-ease-out) both;
}

.vic-toast.is-leaving {
  animation: vic-toast-out var(--vic-duration-fast) var(--vic-ease-in) both;
}

@keyframes vic-toast-in {
  from { opacity: 0; transform: translateX(12px); }
  to   { opacity: 1; transform: translateX(0); }
}
@keyframes vic-toast-out {
  from { opacity: 1; transform: translateX(0); max-height: 80px; margin-bottom: 0; }
  to   { opacity: 0; transform: translateX(12px); max-height: 0; margin-bottom: calc(-1 * var(--vic-space-2)); }
}

.vic-toast__icon {
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  font-size: 1rem;
  line-height: 1;
  margin-top: 1px;
}

.vic-toast__body {
  flex: 1;
  min-width: 0;
}

.vic-toast__title {
  font-family: var(--vic-font-body);
  font-size: var(--vic-text-sm);
  font-weight: var(--vic-weight-semibold);
  color: var(--vic-color-text);
  line-height: var(--vic-leading-snug);
}

.vic-toast__message {
  font-family: var(--vic-font-body);
  font-size: var(--vic-text-xs);
  color: var(--vic-color-text-muted);
  margin-top: 2px;
  line-height: var(--vic-leading-normal);
}

.vic-toast__dismiss {
  flex-shrink: 0;
  background: transparent;
  border: none;
  color: var(--vic-color-text-muted);
  cursor: pointer;
  font-size: 0.9rem;
  line-height: 1;
  padding: 2px;
  border-radius: var(--vic-radius-sm);
  transition: color var(--vic-duration-fast) var(--vic-ease-standard);
  margin-top: 1px;
}
.vic-toast__dismiss:hover { color: var(--vic-color-text); }

/* Variants */
.vic-toast--success {
  border-left: 3px solid var(--vic-color-success);
}
.vic-toast--success .vic-toast__icon { color: var(--vic-color-success); }

.vic-toast--warning {
  border-left: 3px solid var(--vic-color-warning);
}
.vic-toast--warning .vic-toast__icon { color: var(--vic-color-warning); }

.vic-toast--error {
  border-left: 3px solid var(--vic-color-danger);
}
.vic-toast--error .vic-toast__icon { color: var(--vic-color-danger); }

.vic-toast--info {
  border-left: 3px solid var(--vic-color-accent);
}
.vic-toast--info .vic-toast__icon { color: var(--vic-color-accent); }

/* Barre de progression (durée auto-dismiss) */
.vic-toast__progress {
  position: absolute;
  bottom: 0;
  left: 0;
  height: 2px;
  background: currentColor;
  opacity: 0.35;
  border-radius: 0 0 0 var(--vic-radius-lg);
  animation: vic-toast-progress linear forwards;
}
.vic-toast {
  position: relative;
  overflow: hidden;
}

@keyframes vic-toast-progress {
  from { width: 100%; }
  to   { width: 0%; }
}

@media (max-width: 480px) {
  .vic-toaster {
    top: auto;
    bottom: var(--vic-space-4);
    right: var(--vic-space-3);
    left: var(--vic-space-3);
    max-width: none;
  }
  @keyframes vic-toast-in {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: translateY(0); }
  }
}


/* ════════════════════════════════════════════════════════════════════════
   SKELETON (états de chargement)
   ════════════════════════════════════════════════════════════════════════ */

.vic-skeleton {
  display: block;
  background: linear-gradient(
    90deg,
    var(--vic-color-bg-raised) 25%,
    var(--vic-color-bg-overlay) 50%,
    var(--vic-color-bg-raised) 75%
  );
  background-size: 200% 100%;
  border-radius: var(--vic-radius-sm);
  animation: vic-shimmer 1.4s ease-in-out infinite;
}

@keyframes vic-shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

@media (prefers-reduced-motion: reduce) {
  .vic-skeleton {
    animation: none;
    background: var(--vic-color-bg-raised);
  }
}

/* Variante ligne de texte */
.vic-skeleton--text {
  height: 1em;
  border-radius: var(--vic-radius-pill);
}
.vic-skeleton--text + .vic-skeleton--text { margin-top: var(--vic-space-2); }

/* Variante ligne courte (sous-titre / label) */
.vic-skeleton--text-sm {
  height: 0.75em;
  border-radius: var(--vic-radius-pill);
}

/* Variante cercle (avatar) */
.vic-skeleton--circle {
  border-radius: 50%;
  aspect-ratio: 1;
}

/* Variante bloc rectangulaire (image, carte) */
.vic-skeleton--block {
  border-radius: var(--vic-radius-md);
}

/* Variante bouton */
.vic-skeleton--btn {
  height: 36px;
  width: 80px;
  border-radius: var(--vic-radius-md);
}

/* Groupe skeleton (carte type message) */
.vic-skeleton-group {
  display: flex;
  flex-direction: column;
  gap: var(--vic-space-3);
  padding: var(--vic-space-4);
}

.vic-skeleton-group__header {
  display: flex;
  align-items: center;
  gap: var(--vic-space-3);
}

/* Utilitaires de largeur pour les squelettes texte */
.vic-skeleton--w-full  { width: 100%; }
.vic-skeleton--w-3\/4  { width: 75%; }
.vic-skeleton--w-1\/2  { width: 50%; }
.vic-skeleton--w-1\/3  { width: 33%; }
.vic-skeleton--w-1\/4  { width: 25%; }


/* ════════════════════════════════════════════════════════════════════════
   UTILITAIRES COMPLÉMENTAIRES
   ════════════════════════════════════════════════════════════════════════ */

/* Visually hidden (accessibilité — labels pour lecteurs d'écran) */
.vic-sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* Spinner autonome */
.vic-spinner {
  display: inline-block;
  width: 1em;
  height: 1em;
  border: 2px solid var(--vic-color-border-strong);
  border-top-color: var(--vic-color-accent);
  border-radius: 50%;
  animation: vic-spin var(--vic-duration-slow) linear infinite;
}
.vic-spinner--sm { width: 0.75em; height: 0.75em; }
.vic-spinner--lg { width: 1.5em;  height: 1.5em; border-width: 3px; }

/* Divider */
.vic-divider {
  border: none;
  border-top: 1px solid var(--vic-color-border);
  margin: var(--vic-space-4) 0;
}

/* Badge / tag */
.vic-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--vic-space-1);
  padding: 0.1em var(--vic-space-2);
  border-radius: var(--vic-radius-pill);
  font-family: var(--vic-font-body);
  font-size: var(--vic-text-xs);
  font-weight: var(--vic-weight-medium);
  letter-spacing: var(--vic-tracking-wide);
  text-transform: uppercase;
  border: 1px solid currentColor;
  line-height: 1.4;
}
.vic-badge--gold    { color: var(--vic-color-accent); }
.vic-badge--success { color: var(--vic-color-success); }
.vic-badge--warning { color: var(--vic-color-warning); }
.vic-badge--danger  { color: var(--vic-color-danger); }
.vic-badge--muted   { color: var(--vic-color-text-subtle); }
