/* ===========================================================================
   EcoRide — Composants partagés
   Boutons, cartes, formulaires, badges, messages, onglets.
   =========================================================================== */

/* --- Boutons --- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-5);
  font-weight: var(--font-semibold);
  font-size: var(--text-base);
  line-height: 1;
  border-radius: var(--radius-pill);
  border: 1px solid transparent;
  cursor: pointer;
  transition: transform var(--transition), box-shadow var(--transition),
              background var(--transition), color var(--transition);
  text-align: center;
}
.btn:hover { transform: translateY(-1px); }
.btn:active { transform: translateY(0); }

.btn--primary {
  background: var(--gradient-action);
  color: var(--color-text-invert);
  box-shadow: var(--shadow);
}
.btn--primary:hover { box-shadow: var(--shadow-lg); color: var(--color-text-invert); }

.btn--secondary {
  background: var(--color-surface);
  color: var(--color-primary);
  border-color: var(--color-border-strong);
}
.btn--secondary:hover { background: var(--color-surface-2); color: var(--color-primary); }

.btn--ghost {
  background: transparent;
  color: var(--color-primary);
}
.btn--ghost:hover { background: var(--color-surface-2); }

.btn--danger {
  background: var(--color-danger);
  color: #fff;
}

.btn--block { width: 100%; }
.btn--sm { padding: var(--space-2) var(--space-4); font-size: var(--text-sm); }

/* --- Pilule de compte / lien header --- */
.account-pill {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-4);
  background: var(--color-surface-2);
  color: var(--color-primary);
  font-weight: var(--font-semibold);
  font-size: var(--text-sm);
  border-radius: var(--radius-pill);
  border: 1px solid var(--color-border);
  transition: background var(--transition);
}
.account-pill:hover { background: var(--color-surface-3); color: var(--color-primary); }

/* --- Cartes --- */
.card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: var(--space-5);
  transition: box-shadow var(--transition), transform var(--transition);
}
.card--hover:hover { box-shadow: var(--shadow); transform: translateY(-2px); }

/* --- Formulaires --- */
.form-group { display: flex; flex-direction: column; gap: var(--space-2); }
.form-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
}
.form-row > .form-group { flex: 1 1 180px; }

label { font-weight: var(--font-medium); font-size: var(--text-sm); color: var(--color-text); }

input:not([type="checkbox"]):not([type="radio"]),
select, textarea {
  width: 100%;
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-base);
  color: var(--color-text);
  background: var(--color-surface);
  border: 1px solid var(--color-border-strong);
  border-radius: var(--radius);
  transition: border-color var(--transition), box-shadow var(--transition);
  text-align: center;
}
input:focus, select:focus, textarea:focus {
  border-color: var(--color-accent-soft);
  box-shadow: var(--shadow-focus);
  outline: none;
}
textarea { resize: vertical; min-height: 6rem; }

/* Masque les flèches spinner des inputs number (ex : téléphone) */
input[type="number"]::-webkit-outer-spin-button,
input[type="number"]::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
input[type="number"] { -moz-appearance: textfield; appearance: textfield; }

.error-message {
  color: var(--color-danger);
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
}

/* --- Messages flash (Django messages) --- */
.messages {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  max-width: var(--content-max);
  margin: var(--space-4) auto 0;
  padding-inline: var(--content-pad);
}
.messages li {
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius);
  border-left: 4px solid currentColor;
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
}
.messages .success { background: var(--color-success-bg); color: var(--color-success); margin: 0.5rem ; }
.messages .error { margin: 0.5rem ;}
.messages .danger  { background: var(--color-danger-bg);  color: var(--color-danger); margin: 0.5rem ;}
.messages .warning { background: var(--color-warning-bg); color: var(--color-warning); margin: 0.5rem ;}
.messages .info,
.messages .debug   { background: var(--color-info-bg);    color: var(--color-info); margin: 0.5rem ; }

/* --- Système d'onglets (MonCompte, Modérateur) ---
   Chaque .tab contient un radio caché + un label (bouton) + un .content en
   position absolue. Le radio coché remonte son .content au-dessus des autres. */
#menu-tab { margin-top: var(--space-6); }
.page-wrap { width: 100%; }

.tabs {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: var(--space-1);
}

/* .tab fond dans le flux : ses enfants (radio, label, content) deviennent
   des items flex de .tabs, ce qui permet labels en ligne + contenu plein
   largeur dessous, avec une hauteur libre (la page s'allonge). */
.tab { display: contents; }

.tab > input[type="radio"] {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.tab > label {
  order: 1;                       /* tous les labels d'abord (rangée d'onglets) */
  display: inline-block;
  padding: var(--space-3) var(--space-5);
  font-weight: var(--font-semibold);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-bottom: none;
  border-radius: var(--radius) var(--radius) 0 0;
  cursor: pointer;
  transition: background var(--transition), color var(--transition);
}
.tab > label:hover { background: var(--color-surface-2); color: var(--color-primary); }

.tab > input[type="radio"]:checked ~ label {
  background: var(--color-surface);
  color: var(--color-primary);
  border-color: var(--color-border-strong);
}
.tab > input[type="radio"]:focus-visible ~ label { box-shadow: var(--shadow-focus); }

.content {
  order: 2;                       /* le contenu passe sous la rangée de labels */
  flex: 1 0 100%;
  display: none;                  /* masqué tant que l'onglet n'est pas actif */
  min-height: clamp(260px, 40vh, 460px);
  margin-top: -1px;               /* fusionne avec la bordure du label actif */
  background: var(--color-surface);
  border: 1px solid var(--color-border-strong);
  border-radius: 0 var(--radius-lg) var(--radius-lg) var(--radius-lg);
  box-shadow: var(--shadow);
  padding: var(--space-6);
}
.tab > input[type="radio"]:checked ~ label ~ .content { display: block; }

@media (max-width: 640px) {
  .tab > label { flex: 1 1 auto; text-align: center; border-radius: var(--radius); }
}

/* --- Recherche de trajet (accueil + onglet passager Mon Compte) --- */
.search {
  max-width: 960px;
  margin: var(--space-8) auto;
  text-align: center;
}
.search__title {
  color: var(--color-primary);
  margin-bottom: var(--space-5);
}
.search__form {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  justify-content: center;
  gap: var(--space-4);
  background: var(--color-surface);
  padding: var(--space-5);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow);
  border: 1px solid var(--color-border);
}
.search__form .form-group { flex: 1 1 180px; text-align: left; }
.search__form button { flex: 0 0 auto; }

/* --- Conteneurs de résultats --- */
#resultats { margin-block: var(--space-8); }
.conteneur_recherche {
  background: var(--color-surface-2);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  margin-bottom: var(--space-6);
}
.conteneur_recherche > h2 {
  color: var(--color-primary);
  text-align: center;
  margin-bottom: var(--space-4);
}
.conteneur_recherche2 {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: var(--space-5);
}
.resultat { display: contents; } /* la grille du parent dispose les <li> */

/* --- Carte trajet (label cliquable autour d'un radio caché) --- */
.trajet-radio { position: absolute; opacity: 0; pointer-events: none; }
.trajet-item { list-style: none; }

.trajet-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  height: 100%;
  background: var(--color-surface);
  border: 2px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  cursor: pointer;
  box-shadow: var(--shadow-sm);
  transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition);
  margin: var(--space-2);
}
.trajet-card:hover {
  border-color: var(--color-accent-soft);
  box-shadow: var(--shadow);
  transform: translateY(-3px);
}
.trajet-radio:checked + .trajet-card { border-color: var(--color-accent); box-shadow: var(--shadow-lg); }
.trajet-radio:focus-visible + .trajet-card { box-shadow: var(--shadow-focus); }

.trajet-header { display: flex; align-items: flex-start; justify-content: space-between; gap: var(--space-3); }
.chauffeur-info { display: flex; align-items: center; gap: var(--space-3); }
.chauffeur-photo img {
  width: var(--avatar-md); height: var(--avatar-md);
  border-radius: var(--radius-circle);
  object-fit: cover;
  border: 2px solid var(--color-border-strong);
}
.chauffeur-name { font-weight: var(--font-semibold); }
.chauffeur-rating { font-size: var(--text-sm); color: var(--color-text-muted); }
.rating-value { font-weight: var(--font-medium); color: var(--color-text); }
.no-rating { font-style: italic; }
.deleted-user { color: var(--color-danger); font-style: italic; }

.statut-badge {
  flex-shrink: 0;
  padding: var(--space-1) var(--space-3);
  font-size: var(--text-xs);
  font-weight: var(--font-semibold);
  border-radius: var(--radius-pill);
  background: var(--color-surface-2);
  color: var(--color-primary);
  text-transform: capitalize;
}
.statut-badge.disponible { background: var(--color-success-bg); color: var(--color-success); }
.statut-badge.complet,
.statut-badge.annulé { background: var(--color-danger-bg); color: var(--color-danger); }

.trajet-body { display: flex; flex-direction: column; gap: var(--space-3); }
.trajet-route {
  display: flex; align-items: center; gap: var(--space-3);
  padding: var(--space-3);
  background: var(--color-surface-2);
  border-radius: var(--radius);
}
.route-item { display: flex; align-items: center; gap: var(--space-2); font-weight: var(--font-medium); }
.route-city { color: var(--color-primary); }
.route-arrow { color: var(--color-accent); font-weight: var(--font-bold); }

.trajet-datetime { display: flex; flex-wrap: wrap; gap: var(--space-3); font-size: var(--text-sm); color: var(--color-text-muted); }
.datetime-item { display: flex; align-items: center; gap: var(--space-1); }

.trajet-car { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: var(--space-2); font-size: var(--text-sm); }
.car-model { display: flex; align-items: center; gap: var(--space-2); font-weight: var(--font-medium); }
.engine-badge {
  display: inline-flex; align-items: center; gap: var(--space-1);
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-pill);
  font-weight: var(--font-semibold);
  font-size: var(--text-xs);
  background: var(--color-surface-3);
  color: var(--color-primary);
}
.engine-badge.electrique { background: #d8f3dc; color: #1b4332; }
.engine-badge.hybride { background: #fff3cd; color: #856404; }
.engine-badge.essence,
.engine-badge.diesel { background: #f1f1f1; color: #555; }

.trajet-footer {
  display: flex; align-items: center; justify-content: space-between; gap: var(--space-3);
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-border);
  margin-top: auto;
}
.trajet-prix { display: flex; flex-direction: column; }
.prix-label { font-size: var(--text-xs); color: var(--color-text-muted); text-transform: uppercase; letter-spacing: .05em; }
.prix-value { font-size: var(--text-xl); font-weight: var(--font-bold); color: var(--color-primary); }
.places-available { color: var(--color-success); font-weight: var(--font-medium); }
.places-full { color: var(--color-danger); font-weight: var(--font-medium); }

.selection-indicator {
  position: absolute; top: var(--space-3); right: var(--space-3);
  width: 28px; height: 28px;
  display: grid; place-items: center;
  border-radius: var(--radius-circle);
  background: var(--color-accent);
  color: #fff;
  opacity: 0; transform: scale(.6);
  transition: opacity var(--transition), transform var(--transition);
}
.trajet-radio:checked + .trajet-card .selection-indicator { opacity: 1; transform: scale(1); }

/* --- Formulaire de filtre + actions résultats --- */
#filtre_form {
  display: flex; flex-wrap: wrap; align-items: flex-end; justify-content: center;
  gap: var(--space-4);
  background: var(--color-surface);
  padding: var(--space-5);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--color-border);
  margin-bottom: var(--space-6);
}
.form-actions { display: flex; flex-wrap: wrap; justify-content: center; gap: var(--space-3); margin-top: var(--space-6); }
#reservation_btn { margin-top: var(--space-4); }
#resultat_non_ecolo,
#resultat_ecolo {
  grid-column: 1 / -1;
  text-align: center;
  padding: var(--space-6);
  color: var(--color-text-muted);
  font-weight: var(--font-medium);
}

/* --- Titre de section illustré (véhicules, modération) --- */
.vehicle-title {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  font-size: var(--text-lg);
  font-weight: var(--font-bold);
  padding: var(--space-3);
  margin-bottom: var(--space-5);
  background: linear-gradient(135deg, var(--color-surface-3) 0%, var(--color-accent-pale) 100%);
  color: var(--color-success);
  border-radius: var(--radius);
}

/* --- Badges --- */
.badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: var(--space-1) var(--space-3);
  font-size: var(--text-xs);
  font-weight: var(--font-semibold);
  border-radius: var(--radius-pill);
  background: var(--color-surface-2);
  color: var(--color-primary);
}
.badge--success { background: var(--color-success-bg); color: var(--color-success); }
.badge--danger  { background: var(--color-danger-bg);  color: var(--color-danger); }
.badge--warning { background: var(--color-warning-bg); color: var(--color-warning); }
