/**
 * LLA Marketplace Components
 * Version: 2.0.0
 * 
 * Composants réutilisables pour toutes les extensions
 * Buttons, Cards, Pills, Badges, Forms, etc.
 */

/* ============================================
   BUTTONS
   ============================================ */

/* Base button - Reset complet WooCommerce */
.lla-btn,
button.lla-btn,
a.lla-btn,
input[type="submit"].lla-btn,
.lla-marketplace .button.lla-btn,
.lla-marketplace .woocommerce-button.lla-btn {
  /* Reset total */
  all: unset;
  box-sizing: border-box !important;
  
  /* Nos styles */
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: var(--lla-space-2) !important;
  padding: var(--lla-space-3) var(--lla-space-6) !important;
  font-size: var(--lla-text-base) !important;
  font-weight: var(--lla-font-medium) !important;
  line-height: 1 !important;
  border-radius: var(--lla-radius-lg) !important;
  cursor: pointer !important;
  transition: all var(--lla-transition-base) !important;
  text-decoration: none !important;
  border: none !important;
  white-space: nowrap !important;
  user-select: none !important;
}

/* Primary button - Or artisan */
.lla-btn-primary {
  background: var(--lla-primary) !important;
  color: var(--lla-white) !important;
  box-shadow: var(--lla-shadow-sm) !important;
}

.lla-btn-primary:hover {
  background: var(--lla-primary-hover) !important;
  box-shadow: var(--lla-shadow-md) !important;
  transform: translateY(-1px) !important;
}

.lla-btn-primary:active {
  transform: translateY(0) !important;
  box-shadow: var(--lla-shadow-sm) !important;
}

/* Secondary button - Brun */
.lla-btn-secondary {
  background: var(--lla-secondary) !important;
  color: var(--lla-white) !important;
  box-shadow: var(--lla-shadow-sm) !important;
}

.lla-btn-secondary:hover {
  background: var(--lla-secondary-hover) !important;
  box-shadow: var(--lla-shadow-md) !important;
  transform: translateY(-1px) !important;
}

/* Outline button */
.lla-btn-outline {
  background: transparent !important;
  color: var(--lla-primary) !important;
  border: 2px solid var(--lla-primary) !important;
  box-shadow: none !important;
}

.lla-btn-outline:hover {
  background: var(--lla-primary-light) !important;
  border-color: var(--lla-primary-hover) !important;
}

/* Ghost button */
.lla-btn-ghost {
  background: transparent !important;
  color: var(--lla-brown-700) !important;
  box-shadow: none !important;
}

.lla-btn-ghost:hover {
  background: var(--lla-cream-200) !important;
}

/* Button sizes */
.lla-btn-sm {
  padding: var(--lla-space-2) var(--lla-space-4) !important;
  font-size: var(--lla-text-sm) !important;
}

.lla-btn-lg {
  padding: var(--lla-space-4) var(--lla-space-8) !important;
  font-size: var(--lla-text-lg) !important;
}

/* Button états */
.lla-btn:disabled,
.lla-btn.disabled {
  opacity: 0.5 !important;
  cursor: not-allowed !important;
  pointer-events: none !important;
}

.lla-btn-loading {
  position: relative !important;
  color: transparent !important;
}

.lla-btn-loading::after {
  content: "" !important;
  position: absolute !important;
  width: 16px !important;
  height: 16px !important;
  top: 50% !important;
  left: 50% !important;
  margin: -8px 0 0 -8px !important;
  border: 2px solid var(--lla-white) !important;
  border-top-color: transparent !important;
  border-radius: 50% !important;
  animation: lla-spin 0.6s linear infinite !important;
}

/* ============================================
   CARDS
   ============================================ */

/* Base card */
.lla-card {
  background: var(--lla-white) !important;
  border-radius: var(--lla-radius-xl) !important;
  box-shadow: var(--lla-shadow-sm) !important;
  transition: all var(--lla-transition-base) !important;
  overflow: hidden !important;
}

.lla-card:hover {
  box-shadow: var(--lla-shadow-lg) !important;
  transform: translateY(-2px) !important;
}

/* Card header */
.lla-card-header {
  padding: var(--lla-space-6) !important;
  border-bottom: 1px solid var(--lla-beige-300) !important;
}

/* Card body */
.lla-card-body {
  padding: var(--lla-space-6) !important;
}

/* Card footer */
.lla-card-footer {
  padding: var(--lla-space-6) !important;
  border-top: 1px solid var(--lla-beige-300) !important;
  background: var(--lla-cream-50) !important;
}

/* Card variants */
.lla-card-flat {
  box-shadow: none !important;
  border: 1px solid var(--lla-beige-300) !important;
}

.lla-card-elevated {
  box-shadow: var(--lla-shadow-lg) !important;
}

/* ============================================
   PILLS / TAGS
   ============================================ */

/* Base pill - Force priorité sur styles existants */
.lla-pill,
label.lla-pill,
.lla-marketplace .pill,
.lla-marketplace label.pill,
.price-pill,
[class*="lla-"] .pill {
  /* Reset */
  all: unset;
  box-sizing: border-box !important;
  
  /* Styles */
  display: inline-flex !important;
  align-items: center !important;
  gap: var(--lla-space-2) !important;
  padding: var(--lla-space-2) var(--lla-space-4) !important;
  font-size: var(--lla-text-sm) !important;
  font-weight: var(--lla-font-medium) !important;
  line-height: 1.5 !important;
  background: var(--lla-white) !important;
  color: var(--lla-brown-700) !important;
  border: 1px solid var(--lla-beige-300) !important;
  border-radius: var(--lla-radius-full) !important;
  cursor: pointer !important;
  transition: all var(--lla-transition-base) !important;
  white-space: nowrap !important;
  user-select: none !important;
}

.lla-pill:hover,
label.lla-pill:hover {
  background: var(--lla-cream-200) !important;
  border-color: var(--lla-beige-400) !important;
}

/* Active state - Or artisan */
.lla-pill.active,
.lla-pill.is-active,
label.lla-pill.active,
input:checked + .lla-pill {
  background: var(--lla-primary-light) !important;
  color: var(--lla-secondary) !important;
  border-color: var(--lla-primary) !important;
  font-weight: var(--lla-font-semibold) !important;
}

/* Pill with icon */
.lla-pill svg {
  width: 16px !important;
  height: 16px !important;
  flex-shrink: 0 !important;
}

/* Pill sizes */
.lla-pill-sm {
  padding: var(--lla-space-1) var(--lla-space-3) !important;
  font-size: var(--lla-text-xs) !important;
}

.lla-pill-lg {
  padding: var(--lla-space-3) var(--lla-space-6) !important;
  font-size: var(--lla-text-base) !important;
}

/* ============================================
   BADGES
   ============================================ */

/* Base badge */
.lla-badge {
  display: inline-flex !important;
  align-items: center !important;
  gap: var(--lla-space-1) !important;
  padding: var(--lla-space-1) var(--lla-space-2) !important;
  font-size: var(--lla-text-xs) !important;
  font-weight: var(--lla-font-semibold) !important;
  line-height: 1 !important;
  border-radius: var(--lla-radius-md) !important;
  white-space: nowrap !important;
}

/* Badge variants */
.lla-badge-primary {
  background: var(--lla-primary-light) !important;
  color: var(--lla-primary-dark) !important;
}

.lla-badge-success {
  background: var(--lla-success-light) !important;
  color: var(--lla-success) !important;
}

.lla-badge-warning {
  background: var(--lla-warning-light) !important;
  color: var(--lla-warning) !important;
}

.lla-badge-error {
  background: var(--lla-error-light) !important;
  color: var(--lla-error) !important;
}

.lla-badge-info {
  background: var(--lla-info-light) !important;
  color: var(--lla-info) !important;
}

/* Badge avec dot */
.lla-badge-dot::before {
  content: "" !important;
  display: inline-block !important;
  width: 6px !important;
  height: 6px !important;
  border-radius: 50% !important;
  background: currentColor !important;
}

/* ============================================
   FORMS
   ============================================ */

/* Input fields */
.lla-input,
.lla-marketplace input[type="text"],
.lla-marketplace input[type="email"],
.lla-marketplace input[type="password"],
.lla-marketplace input[type="number"],
.lla-marketplace input[type="search"],
.lla-marketplace textarea,
.lla-marketplace select {
  width: 100% !important;
  padding: var(--lla-space-3) var(--lla-space-4) !important;
  font-size: var(--lla-text-base) !important;
  line-height: var(--lla-leading-normal) !important;
  color: var(--lla-brown-900) !important;
  background: var(--lla-white) !important;
  border: 1px solid var(--lla-beige-300) !important;
  border-radius: var(--lla-radius-lg) !important;
  transition: all var(--lla-transition-base) !important;
}

.lla-input:focus,
.lla-marketplace input:focus,
.lla-marketplace textarea:focus,
.lla-marketplace select:focus {
  outline: none !important;
  border-color: var(--lla-primary) !important;
  box-shadow: 0 0 0 3px rgba(215, 153, 66, 0.1) !important;
}

.lla-input::placeholder {
  color: var(--lla-brown-500) !important;
}

/* Checkbox & Radio */
.lla-checkbox,
.lla-radio {
  width: 20px !important;
  height: 20px !important;
  border: 2px solid var(--lla-beige-400) !important;
  border-radius: var(--lla-radius-sm) !important;
  cursor: pointer !important;
  transition: all var(--lla-transition-fast) !important;
}

.lla-radio {
  border-radius: 50% !important;
}

.lla-checkbox:checked,
.lla-radio:checked {
  background: var(--lla-primary) !important;
  border-color: var(--lla-primary) !important;
}

/* ============================================
   LOADING STATES
   ============================================ */

/* Skeleton loader */
.lla-skeleton {
  background: linear-gradient(
    90deg,
    var(--lla-cream-200) 0%,
    var(--lla-cream-100) 50%,
    var(--lla-cream-200) 100%
  ) !important;
  background-size: 200% 100% !important;
  animation: lla-skeleton-loading 1.5s ease-in-out infinite !important;
  border-radius: var(--lla-radius-lg) !important;
}

@keyframes lla-skeleton-loading {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

.lla-skeleton-text {
  height: 1em !important;
  margin-bottom: var(--lla-space-2) !important;
}

.lla-skeleton-avatar {
  width: 48px !important;
  height: 48px !important;
  border-radius: 50% !important;
}

/* Spinner */
.lla-spinner {
  width: 32px !important;
  height: 32px !important;
  border: 3px solid var(--lla-cream-300) !important;
  border-top-color: var(--lla-primary) !important;
  border-radius: 50% !important;
  animation: lla-spin 0.8s linear infinite !important;
}

.lla-spinner-sm {
  width: 16px !important;
  height: 16px !important;
  border-width: 2px !important;
}

/* ============================================
   TOOLTIPS
   ============================================ */

.lla-tooltip {
  position: relative !important;
}

.lla-tooltip::after {
  content: attr(data-tooltip) !important;
  position: absolute !important;
  bottom: 100% !important;
  left: 50% !important;
  transform: translateX(-50%) translateY(-8px) !important;
  padding: var(--lla-space-2) var(--lla-space-3) !important;
  background: var(--lla-brown-900) !important;
  color: var(--lla-white) !important;
  font-size: var(--lla-text-sm) !important;
  border-radius: var(--lla-radius-md) !important;
  white-space: nowrap !important;
  opacity: 0 !important;
  pointer-events: none !important;
  transition: opacity var(--lla-transition-base) !important;
  z-index: var(--lla-z-tooltip) !important;
}

.lla-tooltip:hover::after {
  opacity: 1 !important;
}

/* ============================================
   MODALS
   ============================================ */

.lla-modal-overlay {
  position: fixed !important;
  inset: 0 !important;
  background: rgba(48, 37, 29, 0.5) !important;
  backdrop-filter: blur(4px) !important;
  z-index: var(--lla-z-overlay) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: var(--lla-space-4) !important;
  animation: lla-fade-in 0.2s ease-out !important;
}

.lla-modal {
  background: var(--lla-white) !important;
  border-radius: var(--lla-radius-2xl) !important;
  box-shadow: var(--lla-shadow-xl) !important;
  max-width: 500px !important;
  width: 100% !important;
  max-height: 90vh !important;
  overflow-y: auto !important;
  animation: lla-modal-appear 0.3s ease-out !important;
}

@keyframes lla-modal-appear {
  from {
    opacity: 0;
    transform: scale(0.95);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}

/* ============================================
   ALERTS
   ============================================ */

.lla-alert {
  padding: var(--lla-space-4) !important;
  border-radius: var(--lla-radius-lg) !important;
  display: flex !important;
  gap: var(--lla-space-3) !important;
  align-items: flex-start !important;
}

.lla-alert-success {
  background: var(--lla-success-light) !important;
  color: var(--lla-success) !important;
  border-left: 4px solid var(--lla-success) !important;
}

.lla-alert-warning {
  background: var(--lla-warning-light) !important;
  color: var(--lla-warning) !important;
  border-left: 4px solid var(--lla-warning) !important;
}

.lla-alert-error {
  background: var(--lla-error-light) !important;
  color: var(--lla-error) !important;
  border-left: 4px solid var(--lla-error) !important;
}

.lla-alert-info {
  background: var(--lla-info-light) !important;
  color: var(--lla-info) !important;
  border-left: 4px solid var(--lla-info) !important;
}

/* ============================================
   PROMO BADGES (Events & Sales)
   ============================================ */

/* Badge promo personnalisé - inline au-dessus du prix */
.lla-badge-promo {
  display: inline-flex !important;
  align-items: center !important;
  padding: 4px 10px !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  color: #ffffff !important;
  border-radius: 4px !important;
}

/* Badge promo sur fiche produit (positionné sur l'image) */
.lla-promo-badge {
  display: inline-flex !important;
  align-items: center !important;
  padding: 4px 12px !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  color: #ffffff !important;
  border-radius: 4px !important;
  position: absolute !important;
  top: 10px !important;
  left: 10px !important;
  z-index: 10 !important;
  box-shadow: 0 2px 4px rgba(0,0,0,0.2) !important;
}

/* Badges spécifiques */
.lla-badge-sale {
  background: #EF4444 !important;
  color: #fff !important;
}

.lla-badge-new {
  background: #10B981 !important;
  color: #fff !important;
}

.lla-badge-featured {
  background: linear-gradient(135deg, #F59E0B, #D97706) !important;
  color: #fff !important;
}

/* Container des badges sur les cartes - inline, pas absolute */
.lla-card-badges {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 6px !important;
  margin-bottom: 8px !important;
}

.lla-card-badges .lla-badge {
  position: relative !important;
  top: auto !important;
  left: auto !important;
}
