/* assets/css/contrat.css */

/* Messages (sans popup) */
.flash-ok{
  background:#d4edda;
  color:#155724;
  padding:10px;
  border-radius:6px;
  margin: 10px 0;
  border:1px solid #bfe7c7;
}

.flash-err{
  background:#ffecec;
  color:#7a1c1c;
  padding:10px;
  border-radius:6px;
  margin: 10px 0;
  border:1px solid #ffc2c2;
}

/* Bouton Annuler (même style que btn-save mais gris) */
.btn-cancel{
  background:#e9e9e9;
  color:#222;
  border:none;
  padding:10px 18px;
  border-radius:5px;
  cursor:pointer;
  font-weight:bold;
  text-decoration:none;
  display:inline-block;
}

/* Zone boutons centrée */
.actions-center{
  display:flex;
  justify-content:center;
  gap:30px;
  margin-top:15px;
}

/* Pastilles (si besoin dans contrats_info) */
.pastille{
  display:inline-block;
  width:10px;
  height:10px;
  border-radius:50%;
  margin-left:4px;
}
.pastille-rouge{ background:#e74c3c; }
.pastille-orange{ background:#e67e22; }
.pastille-verte{ background:#2ecc71; }

/* Petits badges statut */
.badge{
  display:inline-block;
  padding:3px 8px;
  border-radius:999px;
  font-size:12px;
  border:1px solid #ddd;
  background:#fff;
}
.badge-actif{ border-color:#bfe7c7; background:#e7f6ea; color:#155724; }
.badge-brouillon{ border-color:#ffe1c7; background:#fff4ea; color:#7a4a1c; }
.badge-annule{ border-color:#ffc2c2; background:#ffecec; color:#7a1c1c; }

/* =========================================================
   AJOUTS : styles nécessaires pour creation_contrats.php
========================================================= */
.contrat-box{ font-size:14px; }

.section-title{
  margin:8px 0 10px;
  padding:10px 12px;
  background:#428e9b;
  color:#fff;
  font-weight:bold;
  text-transform:uppercase;
  font-size:13px;
  border-radius:4px;
}

.grid-2{ display:flex; gap:18px; flex-wrap:wrap; align-items:flex-start; }
.col{ flex:1; min-width:340px; }
.row{ display:flex; gap:12px; flex-wrap:wrap; }
.field{ display:flex; flex-direction:column; gap:4px; margin-bottom:10px; flex:1; min-width:180px; }
.field label{ font-weight:bold; font-size:12px; color:#5a5a5a; }
.field input, .field select, .field textarea{
  padding:8px 10px; border:1px solid #ddd; border-radius:4px; outline:none;
}
.field input:focus, .field select:focus, .field textarea:focus{ border-color:#428e9b; }

.full-width{ width:100%; margin-top:10px; }

.btn-save{ background:#428e9b; color:#fff; border:none; padding:10px 16px; border-radius:4px; font-weight:bold; cursor:pointer; }
.btn-save:hover{ background:#35717c; }
.btn-draft{ background:#e58338; color:#fff; border:none; padding:10px 16px; border-radius:4px; font-weight:bold; cursor:pointer; }
.btn-draft:hover{ background:#cf6f2b; }

.small-note{ font-size:12px; color:#777; margin-top:6px; }
.base-note{ font-size:12px; color:#777; margin-top:4px; }
.base-note b{ color:#444; }
.changed{ border-color:#e58338 !important; background:#fff8f3; }

/* Recherche client */
.client-results{ border:1px solid #eee; border-radius:4px; background:#fff; max-height:160px; overflow:auto; }
.client-item{ padding:8px 10px; border-bottom:1px solid #f1f1f1; cursor:pointer; font-size:13px; display:flex; justify-content:space-between; gap:10px; }
.client-item:hover{ background:#f7fbfc; }
.client-name{ font-weight:bold; color:#428e9b; }
.client-meta{ color:#666; font-size:12px; }
.client-tools{ display:flex; gap:8px; margin-top:6px; align-items:center; }
.btn-mini{ padding:6px 10px; border:1px solid #ddd; border-radius:4px; background:#fff; cursor:pointer; font-weight:bold; font-size:12px; }
.btn-mini:hover{ border-color:#428e9b; }

/* Stands */
.stand-wrap{
  display:flex; gap:16px; flex-wrap:wrap;
  border:1px dashed #e58338; background:#fff9f5;
  padding:12px; border-radius:4px;
}
.stand-left{ flex:2; min-width:420px; }
.stand-right{ flex:1; min-width:320px; }
.stand-filter{ display:flex; gap:10px; flex-wrap:wrap; margin-bottom:10px; }
.stand-filter input{ flex:1; min-width:220px; }
.stand-list{ border:1px solid #eee; border-radius:4px; max-height:260px; overflow:auto; background:#fff; }
.stand-item{ display:flex; justify-content:space-between; gap:10px; padding:8px 10px; border-bottom:1px solid #f1f1f1; cursor:pointer; font-size:13px; align-items:center; }
.stand-item:hover{ background:#f7fbfc; }
.stand-ref{ font-weight:bold; color:#428e9b; min-width:90px; }
.stand-des{ color:#555; flex:1; }
.stand-count{ font-size:12px; color:#777; margin-top:6px; }

.secondary-box{
  border:1px solid #eee; border-radius:4px; background:#fff;
  padding:8px; max-height:160px; overflow:auto;
}
.secondary-item{ display:flex; align-items:center; gap:8px; margin:6px 0; font-size:13px; }
.secondary-item.disabled{ opacity:0.45; }

/* Options */
.options-wrap{
  border:1px dashed #e58338; background:#fff9f5;
  padding:12px; border-radius:4px;
}
.options-grid{ display:flex; flex-wrap:wrap; gap:10px 18px; }
.opt-card{
  border:1px solid #eee; background:#fff; border-radius:4px;
  padding:10px; min-width:320px; flex:1;
}
.opt-title{ font-weight:bold; color:#428e9b; margin-bottom:4px; }
.opt-desc{ font-size:12px; color:#666; margin-bottom:8px; }
.opt-meta{ font-size:12px; color:#777; margin-top:6px; }
.opt-line{ display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.opt-line input[type="checkbox"]{ transform:scale(1.15); }

/* Modes stands + quotas */
.stand-mode{ display:flex; flex-wrap:wrap; gap:10px; margin:8px 0 10px; }
.mode-pill{
  display:flex; align-items:center; gap:8px;
  padding:8px 10px; border:1px solid #ddd; border-radius:999px;
  background:#fff; cursor:pointer; user-select:none;
  font-weight:bold; font-size:12px; color:#444;
}
.mode-pill input{ transform:scale(1.05); }
.mode-pill.active{ border-color:#428e9b; box-shadow:0 0 0 2px rgba(66,142,155,0.10); }

.quota-badge{
  display:inline-flex; align-items:center; gap:8px;
  padding:4px 8px; border:1px solid #eee; border-radius:999px;
  background:#fafafa; font-size:12px; color:#555; white-space:nowrap;
}
.quota-tag{
  padding:2px 6px; border-radius:999px;
  background:#e58338; color:#fff; font-size:11px; font-weight:bold;
}
.stand-group-tag{
  padding:2px 6px; border-radius:999px;
  border:1px solid #eee; background:#fff; font-size:11px; color:#777;
  white-space:nowrap;
}

.partage-row{ border-bottom:1px solid #f1f1f1; padding:8px 6px; }
.partage-main{ display:flex; justify-content:space-between; gap:10px; align-items:center; }
.partage-tools{ display:flex; flex-wrap:wrap; gap:10px; align-items:center; margin-top:6px; }
.mini-lab{ font-size:12px; color:#666; font-weight:bold; }