/* Composants réutilisables */

/* Boutons */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-sm) var(--spacing-md);
  border: none;
  border-radius: var(--border-radius-md);
  font-size: var(--text-sm);
  font-weight: 500;
  text-decoration: none;
  cursor: pointer;
  transition: all 0.2s ease;
  white-space: nowrap;
}

.btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.btn-primary {
  background-color: var(--color-primary);
  color: var(--color-white);
}

.btn-primary:hover:not(:disabled) {
  background-color: var(--color-primary-dark);
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}

.btn-secondary {
  background-color: var(--color-gray-200);
  color: var(--color-gray-900);
}

.btn-secondary:hover:not(:disabled) {
  background-color: var(--color-gray-300);
}

.btn-success {
  background-color: var(--color-success);
  color: var(--color-white);
}

.btn-warning {
  background-color: var(--color-warning);
  color: var(--color-white);
}

.btn-error {
  background-color: var(--color-error);
  color: var(--color-white);
}

.btn-sm {
  padding: var(--spacing-xs) var(--spacing-sm);
  font-size: var(--text-xs);
}

.btn-lg {
  padding: var(--spacing-md) var(--spacing-lg);
  font-size: var(--text-base);
}

/* Formulaires */
.form-field {
  margin-bottom: var(--spacing-md);
}

.form-field label {
  display: block;
  margin-bottom: var(--spacing-xs);
  font-weight: 500;
  color: var(--color-gray-700);
}

.form-field .required {
  color: var(--color-error);
}

.form-field input,
.form-field select,
.form-field textarea {
  width: 100%;
  padding: var(--spacing-sm) var(--spacing-md);
  border: 1px solid var(--color-gray-300);
  border-radius: var(--border-radius-md);
  font-size: var(--text-base);
  background-color: var(--color-white);
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgb(37 99 235 / 0.1);
}

.form-field textarea {
  min-height: 100px;
  resize: vertical;
}

.form-field input[type="checkbox"] {
  width: auto;
  margin-right: var(--spacing-sm);
}

.form-actions {
  margin-top: var(--spacing-lg);
  padding-top: var(--spacing-md);
  border-top: 1px solid var(--color-gray-200);
  display: flex;
  gap: var(--spacing-sm);
  justify-content: flex-end;
}

/* Messages flash */
.flash-messages {
  margin-bottom: var(--spacing-lg);
}

.flash-message {
  padding: var(--spacing-md);
  border-radius: var(--border-radius-md);
  margin-bottom: var(--spacing-sm);
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-weight: 500;
}

.flash-success {
  background-color: rgb(16 185 129 / 0.1);
  color: var(--color-success);
  border: 1px solid rgb(16 185 129 / 0.2);
}

.flash-error {
  background-color: rgb(239 68 68 / 0.1);
  color: var(--color-error);
  border: 1px solid rgb(239 68 68 / 0.2);
}

.flash-warning {
  background-color: rgb(245 158 11 / 0.1);
  color: var(--color-warning);
  border: 1px solid rgb(245 158 11 / 0.2);
}

.flash-info {
  background-color: rgb(6 182 212 / 0.1);
  color: var(--color-info);
  border: 1px solid rgb(6 182 212 / 0.2);
}

.flash-close {
  background: none;
  border: none;
  font-size: var(--text-lg);
  cursor: pointer;
  color: inherit;
  opacity: 0.7;
  padding: 0;
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.flash-close:hover {
  opacity: 1;
}

/* Badges */
.badge {
  display: inline-flex;
  align-items: center;
  padding: var(--spacing-xs) var(--spacing-sm);
  border-radius: var(--border-radius-sm);
  font-size: var(--text-xs);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.badge-status-a-verifier {
  background-color: rgb(245 158 11 / 0.1);
  color: var(--color-status-a-verifier);
}

.badge-status-libre {
  background-color: rgb(16 185 129 / 0.1);
  color: var(--color-status-libre);
}

.badge-status-occupe {
  background-color: rgb(239 68 68 / 0.1);
  color: var(--color-status-occupe);
}

.badge-status-inaccessible {
  background-color: rgb(107 114 128 / 0.1);
  color: var(--color-status-inaccessible);
}

.badge-status-detruit {
  background-color: rgb(31 41 55 / 0.1);
  color: var(--color-status-detruit);
}

.badge-status-a-nettoyer {
  background-color: rgb(234 179 8 / 0.1);
  color: var(--color-status-a-nettoyer);
}

/* Tableaux */
.table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: var(--spacing-lg);
}

.table th,
.table td {
  padding: var(--spacing-sm) var(--spacing-md);
  text-align: left;
  border-bottom: 1px solid var(--color-gray-200);
}

.table th {
  font-weight: 600;
  color: var(--color-gray-700);
  background-color: var(--color-gray-50);
}

.table tbody tr:hover {
  background-color: var(--color-gray-50);
}

.table-responsive {
  overflow-x: auto;
}

/* Listes */
.list {
  list-style: none;
}

.list-item {
  padding: var(--spacing-md);
  border: 1px solid var(--color-gray-200);
  border-radius: var(--border-radius-md);
  margin-bottom: var(--spacing-sm);
  background-color: var(--color-white);
}

.list-item:hover {
  box-shadow: var(--shadow-sm);
}

/* Navigation */
.nav {
  display: flex;
  gap: var(--spacing-md);
  align-items: center;
}

.nav a {
  color: var(--color-gray-600);
  font-weight: 500;
  padding: var(--spacing-xs) var(--spacing-sm);
  border-radius: var(--border-radius-sm);
  transition: color 0.2s ease;
}

.nav a:hover,
.nav a.active {
  color: var(--color-primary);
  background-color: rgb(37 99 235 / 0.1);
}

/* Indicateurs de chargement */
.loading {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-sm);
  color: var(--color-gray-600);
}

.spinner {
  width: 16px;
  height: 16px;
  border: 2px solid var(--color-gray-300);
  border-top: 2px solid var(--color-primary);
  border-radius: 50%;
  animation: spin 1s linear infinite;
}

@keyframes spin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

/* États d'erreur */
.error-state {
  text-align: center;
  padding: var(--spacing-2xl);
  color: var(--color-gray-600);
}

.error-state h3 {
  color: var(--color-gray-900);
  margin-bottom: var(--spacing-md);
}

/* États vides */
.empty-state {
  text-align: center;
  padding: var(--spacing-2xl);
  color: var(--color-gray-600);
}

.empty-state h3 {
  color: var(--color-gray-900);
  margin-bottom: var(--spacing-md);
}