/**
 * Styles pour le module Réservations
 */

/* ===== CALENDRIER ===== */
.calendar-container {
  background: var(--color-bg-secondary);
  border-radius: var(--radius-lg);
  padding: var(--spacing-lg);
  margin-bottom: var(--spacing-lg);
}

.calendar-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--spacing-lg);
  flex-wrap: wrap;
  gap: var(--spacing-md);
}

.calendar-filters {
  display: flex;
  gap: var(--spacing-md);
  align-items: center;
}

.calendar-filters select {
  padding: var(--spacing-sm) var(--spacing-md);
  border: 1px solid var(--color-border-primary);
  border-radius: var(--radius-sm);
  background: var(--color-bg-primary);
  color: var(--color-text-primary);
}

/* FullCalendar Overrides */
.fc {
  --fc-border-color: var(--color-border-primary);
  --fc-button-bg-color: var(--color-primary);
  --fc-button-border-color: var(--color-primary);
  --fc-button-hover-bg-color: var(--color-primary-hover);
  --fc-button-hover-border-color: var(--color-primary-hover);
  --fc-button-active-bg-color: var(--color-primary-dark);
  --fc-today-bg-color: rgba(59, 130, 246, 0.1);
  --fc-event-border-color: transparent;
  --fc-page-bg-color: var(--color-bg-primary);
  --fc-neutral-bg-color: var(--color-bg-secondary);
}

.fc .fc-toolbar-title {
  color: var(--color-text-primary);
  font-size: 1.25rem;
}

.fc .fc-col-header-cell-cushion,
.fc .fc-daygrid-day-number {
  color: var(--color-text-primary);
}

.fc .fc-daygrid-day.fc-day-today {
  background: var(--fc-today-bg-color);
}

.fc-event {
  cursor: pointer;
  border-radius: var(--radius-sm);
  padding: 2px 4px;
  font-size: 0.8rem;
}

.fc-event-custom {
  padding: 2px;
  overflow: hidden;
}

.fc-event-title {
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.fc-event-details {
  font-size: 0.7rem;
  opacity: 0.9;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.fc-daygrid-event-harness {
  margin-bottom: 2px;
}

/* ===== FORMULAIRE RÉSERVATION ===== */
.reservation-form {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
}

.reservation-form .form-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: var(--spacing-md);
}

.reservation-form .form-group {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
}

.reservation-form label {
  font-weight: 500;
  color: var(--color-text-secondary);
  font-size: 0.9rem;
}

.reservation-form input,
.reservation-form select,
.reservation-form textarea {
  padding: var(--spacing-sm) var(--spacing-md);
  border: 1px solid var(--color-border-primary);
  border-radius: var(--radius-sm);
  background: var(--color-bg-primary);
  color: var(--color-text-primary);
  font-size: 0.95rem;
}

.reservation-form input:focus,
.reservation-form select:focus,
.reservation-form textarea:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.2);
}

/* ===== STATUTS ===== */
.status-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 10px;
  border-radius: var(--radius-full);
  font-size: 0.8rem;
  font-weight: 500;
}

.status-badge.status-pending {
  background: rgba(245, 158, 11, 0.15);
  color: #d97706;
}

.status-badge.status-confirmed {
  background: rgba(59, 130, 246, 0.15);
  color: #2563eb;
}

.status-badge.status-checked_in {
  background: rgba(34, 197, 94, 0.15);
  color: #16a34a;
}

.status-badge.status-checked_out {
  background: rgba(107, 114, 128, 0.15);
  color: #4b5563;
}

.status-badge.status-cancelled {
  background: rgba(239, 68, 68, 0.15);
  color: #dc2626;
}

.status-badge.status-no_show {
  background: rgba(220, 38, 38, 0.15);
  color: #b91c1c;
}

/* ===== LISTE DES RÉSERVATIONS ===== */
.reservations-list {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
}

.reservation-card {
  background: var(--color-bg-secondary);
  border: 1px solid var(--color-border-primary);
  border-radius: var(--radius-md);
  padding: var(--spacing-md);
  transition: box-shadow 0.2s;
}

.reservation-card:hover {
  box-shadow: var(--shadow-md);
}

.reservation-card-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: var(--spacing-sm);
}

.reservation-card-title {
  font-weight: 600;
  color: var(--color-text-primary);
}

.reservation-card-dates {
  font-size: 0.9rem;
  color: var(--color-text-secondary);
}

.reservation-card-body {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: var(--spacing-sm);
  margin-bottom: var(--spacing-sm);
}

.reservation-card-item {
  display: flex;
  flex-direction: column;
}

.reservation-card-label {
  font-size: 0.75rem;
  color: var(--color-text-tertiary);
  text-transform: uppercase;
}

.reservation-card-value {
  font-weight: 500;
  color: var(--color-text-primary);
}

.reservation-card-actions {
  display: flex;
  gap: var(--spacing-sm);
  justify-content: flex-end;
  padding-top: var(--spacing-sm);
  border-top: 1px solid var(--color-border-secondary);
}

/* ===== LOCATAIRES ===== */
.tenant-card {
  background: var(--color-bg-secondary);
  border: 1px solid var(--color-border-primary);
  border-radius: var(--radius-md);
  padding: var(--spacing-md);
}

.tenant-card-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--spacing-sm);
}

.tenant-avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--color-primary);
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
  font-size: 1rem;
}

.tenant-info {
  flex: 1;
  margin-left: var(--spacing-sm);
}

.tenant-name {
  font-weight: 600;
  color: var(--color-text-primary);
}

.tenant-contact {
  font-size: 0.85rem;
  color: var(--color-text-secondary);
}

.tenant-stats {
  display: flex;
  gap: var(--spacing-lg);
  margin-top: var(--spacing-sm);
  padding-top: var(--spacing-sm);
  border-top: 1px solid var(--color-border-secondary);
}

.tenant-stat {
  text-align: center;
}

.tenant-stat-value {
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--color-primary);
}

.tenant-stat-label {
  font-size: 0.75rem;
  color: var(--color-text-tertiary);
}

/* ===== STATISTIQUES OCCUPATION ===== */
.occupancy-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: var(--spacing-md);
  margin-bottom: var(--spacing-lg);
}

.occupancy-card {
  background: var(--color-bg-secondary);
  border: 1px solid var(--color-border-primary);
  border-radius: var(--radius-md);
  padding: var(--spacing-lg);
  text-align: center;
}

.occupancy-value {
  font-size: 2rem;
  font-weight: 700;
  color: var(--color-primary);
}

.occupancy-value.positive {
  color: var(--color-success);
}

.occupancy-value.negative {
  color: var(--color-danger);
}

.occupancy-label {
  font-size: 0.9rem;
  color: var(--color-text-secondary);
  margin-top: var(--spacing-xs);
}

.occupancy-bar {
  height: 8px;
  background: var(--color-bg-tertiary);
  border-radius: var(--radius-full);
  margin-top: var(--spacing-sm);
  overflow: hidden;
}

.occupancy-bar-fill {
  height: 100%;
  background: var(--color-primary);
  border-radius: var(--radius-full);
  transition: width 0.3s ease;
}

/* ===== MODALE RÉSERVATION ===== */
.modal-reservation {
  max-width: 700px;
}

.modal-reservation .modal-body {
  max-height: 70vh;
  overflow-y: auto;
}

.reservation-summary {
  background: var(--color-bg-tertiary);
  border-radius: var(--radius-md);
  padding: var(--spacing-md);
  margin-top: var(--spacing-md);
}

.reservation-summary-row {
  display: flex;
  justify-content: space-between;
  padding: var(--spacing-xs) 0;
}

.reservation-summary-row.total {
  border-top: 1px solid var(--color-border-primary);
  margin-top: var(--spacing-sm);
  padding-top: var(--spacing-sm);
  font-weight: 600;
}

/* ===== RESPONSIVE ===== */
@media (max-width: 768px) {
  .calendar-header {
    flex-direction: column;
    align-items: stretch;
  }
  
  .calendar-filters {
    flex-direction: column;
  }
  
  .calendar-filters select {
    width: 100%;
  }
  
  .fc .fc-toolbar {
    flex-direction: column;
    gap: var(--spacing-sm);
  }
  
  .fc .fc-toolbar-chunk {
    display: flex;
    justify-content: center;
  }
  
  .reservation-card-body {
    grid-template-columns: 1fr 1fr;
  }
}
