/* =========================================================
   CTP Booking – style.css (version corrigée)
   Contrôle Technique Poitiers
   ========================================================= */

/* ----------------------------
   Variables & reset
   ---------------------------- */
:root{
  --accent:#EC6B0F;        /* orange CTP */
  --accent-hover:#d85e0a;  /* orange hover */
  --brand:#0A4B8E;         /* bleu CTP */
  --ink:#151515;
  --muted:#6b7280;
  --bg:#f6f7f9;
  --card:#ffffff;
  --line:#e5e7eb;
  --radius:12px;
  --shadow:0 6px 18px rgba(16,24,40,.06);
  --shadow-sm:0 2px 10px rgba(16,24,40,.06);
  --ring:0 0 0 3px rgba(236,107,15,.15);
  --success:#069669;
}

/* Reset */
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family: system-ui,-apple-system,Segoe UI,Roboto,Inter,Helvetica,Arial,sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.45;
}
h2{margin:0 0 .6rem;font-size:1.25rem;font-weight:700}
p{margin:.3rem 0 .8rem}
.muted{color:var(--muted)}
strong{font-weight:700}
a{color:var(--brand);text-decoration:none}
a:hover{opacity:.9}

/* ----------------------------
   Conteneurs et grilles
   ---------------------------- */
.wrap{width:100%;max-width:1150px;margin:0 auto;padding:0 16px}
.grid-3{
  display:grid;
  grid-template-columns:280px 1fr 260px;
  gap:20px;
  align-items:start;
  margin-top:20px;
  margin-bottom:40px;
}
.stack{display:flex;flex-direction:column;gap:16px}
main.stack, aside.card.pad, #recap{
  background:#fff;
  border-radius:var(--radius);
  align-self:start;
}
.grid-3 > *{
  align-self:start; /* Correction de l’alignement vertical */
}

/* ----------------------------
   Cartes
   ---------------------------- */
.card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}
.pad{padding:18px}
.block{border-top:1px solid var(--line);padding-top:10px;margin-top:10px}
.block .head{font-weight:700;color:#111827;margin-bottom:6px}
.flex{display:flex;justify-content:space-between;align-items:center;margin:.35rem 0}
.flex.total{font-size:1.05rem}
.sticky{position:sticky;top:18px}

/* ----------------------------
   Barre de progression
   ---------------------------- */
.progress-bar{background:#fff;border-bottom:1px solid var(--line)}
.progress-steps{display:flex;gap:8px;align-items:center;padding:12px 0}
.progress-step{
  padding:6px 10px;border-radius:999px;border:1px solid var(--line);
  color:var(--muted);font-weight:600;background:#fff
}
.progress-step.active{border-color:var(--accent);color:var(--accent)}
.progress-line{width:100%;height:4px;border-radius:999px;background:#eef0f3;position:relative}
.progress-line-fill{
  position:absolute;left:0;top:0;height:100%;width:0%;
  background:linear-gradient(90deg,var(--accent),#ff994a);
  border-radius:999px;transition:width .35s ease
}

/* ----------------------------
   Formulaires
   ---------------------------- */
label{font-weight:600}
input,select,textarea{
  width:100%;height:44px;padding:10px 12px;
  border:1px solid var(--line);border-radius:10px;
  background:#fff;font-size:14px;outline:none;
  transition:border-color .2s, box-shadow .2s;
}
input:focus,select:focus{border-color:var(--brand);box-shadow:0 0 0 3px rgba(10,75,142,.12)}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.hidden{display:none!important}

/* ----------------------------
   Boutons navigation
   ---------------------------- */
.nav-buttons{display:flex;gap:10px;margin:8px 0}
.next-btn,.back-btn{
  appearance:none;border:0;border-radius:999px;height:44px;padding:0 20px;
  display:inline-flex;align-items:center;justify-content:center;
  font-weight:800;cursor:pointer;transition:all .2s ease;
}
.next-btn{background:var(--accent);color:#fff}
.next-btn:hover{background:var(--accent-hover)}
.back-btn{background:#f2f3f5;color:var(--accent);border:1px solid var(--accent)}
.back-btn:hover{background:#fff5ef}
.next-btn:disabled{opacity:.5;cursor:not-allowed}

/* ----------------------------
   Calendrier
   ---------------------------- */
.cal{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.cal-month{border:1px solid var(--line);border-radius:12px;background:#fff}
.cal-head{padding:10px 12px;border-bottom:1px solid var(--line)}
.cal-title{text-transform:capitalize;font-weight:700}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;padding:10px}
.cal-dow{color:var(--muted);font-weight:600;text-align:center;font-size:12px}
.cal-cell{
  height:42px;border:1px solid var(--line);border-radius:10px;background:#fff;
  display:flex;align-items:center;justify-content:center;position:relative;
  cursor:pointer;transition:all .2s ease
}
.cal-cell:hover{border-color:var(--brand)}
.cal-cell.empty{background:#fafafa;border-style:dashed}
.cal-cell.disabled{opacity:.4;cursor:not-allowed;background:#fafafa}
.cal-cell.selected{outline:2px solid var(--accent);box-shadow:var(--ring)}

/* Correction badge férié */
.cal-badge{
  position:absolute;
  right:4px;top:4px;
  background:#fee2e2;color:#b91c1c;
  font-size:10px;
  padding:1px 4px;
  border-radius:999px;
  border:1px solid #fecaca;
  white-space:nowrap;
}

/* ----------------------------
   Créneaux horaires
   ---------------------------- */
.slot-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}
.slot-btn{
  height:40px;border:1px solid var(--line);border-radius:10px;background:#fff;cursor:pointer;
  font-weight:700;transition:all .2s ease
}
.slot-btn:hover{border-color:var(--brand)}
.slot-btn.active{outline:2px solid var(--accent);box-shadow:var(--ring)}

/* ----------------------------
   Paiement
   ---------------------------- */
.pay-options{display:flex;flex-direction:column;gap:10px;margin-bottom:10px}
.pay-option{display:block}
.pay-option input{display:none}
.option-card{
  display:flex;align-items:center;justify-content:space-between;
  gap:16px;padding:14px 16px;border:1px solid var(--line);border-radius:14px;
  background:#fff;box-shadow:var(--shadow-sm);transition:all .25s ease
}
.option-left{display:flex;align-items:center;gap:12px;min-width:0}
.option-title{font-weight:800}
.option-hint{color:var(--muted);font-weight:600;margin-left:6px}
.option-right{display:flex;align-items:center;gap:12px}
.brand-icons{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.brand-svg{height:24px;border-radius:6px;box-shadow:0 1px 3px rgba(16,24,40,.08)}
@media (max-width:560px){.brand-svg{height:20px}}
.radio-dot{
  width:18px;height:18px;border-radius:999px;border:2px solid #b6c6d6;
  display:inline-block;position:relative;background:#fff
}
.pay-option input:checked + .option-card{
  outline:2px solid var(--accent);
  box-shadow:var(--ring);
}
.pay-option input:checked + .option-card .radio-dot{border-color:var(--accent)}
.pay-option input:checked + .option-card .radio-dot::after{
  content:"";position:absolute;inset:3px;border-radius:999px;background:var(--accent)
}

/* Bloc carte CB */
#card-form{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:10px;
  border:1px dashed var(--line);border-radius:10px;background:#fafafa;
}
#card-form label{font-weight:600}
#card-form input{background:#fff}
#card-form.hidden{display:none!important}

/* ----------------------------
   Responsive
   ---------------------------- */
@media (max-width:1024px){
  .grid-3{grid-template-columns:1fr;gap:14px}
  .sticky{position:relative;top:auto}
  .cal{grid-template-columns:1fr}
  .slot-grid{grid-template-columns:repeat(4,1fr)}
}
@media (max-width:640px){
  .grid-2{grid-template-columns:1fr}
  .slot-grid{grid-template-columns:repeat(3,1fr)}
}
/* ===== Hotfix WordPress / Elementor (scopé) ===== */
#ctp-booking .wrap{margin-top:0 !important}
#ctp-booking .progress-bar{margin-bottom:12px !important}

/* Aligner les 3 colonnes au même niveau */
#ctp-booking .grid-3{align-items:flex-start !important}
#ctp-booking .grid-3 > *{align-self:flex-start !important; margin-top:0 !important}

/* Neutraliser marges parasites Elementor / thème */
#ctp-booking h2:first-child{margin-top:0 !important}
#ctp-booking .elementor-widget-container > *:first-child{margin-top:0 !important}
#ctp-booking .elementor-widget-container > *:last-child{margin-bottom:0 !important}

/* Badge férié : pas de chevauchement */
#ctp-booking .cal-cell{overflow:hidden !important; position:relative}
#ctp-booking .cal-badge{z-index:2; right:4px; top:4px}

/* Boutons : forcer l’orange CTP */
#ctp-booking .next-btn{
  background:#EC6B0F !important; color:#fff !important; border-color:#EC6B0F !important;
}
#ctp-booking .next-btn:hover{background:#d85e0a !important}
#ctp-booking .back-btn{
  background:#f2f3f5 !important; color:#EC6B0F !important; border:1px solid #EC6B0F !important;
}
#ctp-booking .back-btn:hover{background:#fff5ef !important}

/* Éviter qu’Elementor sur-stylise nos boutons */
#ctp-booking .next-btn, 
#ctp-booking .back-btn{
  box-shadow:none !important; text-transform:none !important; letter-spacing:0 !important;
}

/* Cartes : même départ haut et mêmes espacements */
#ctp-booking .card.pad{padding:18px !important}
#ctp-booking .card.pad > h2{margin-bottom:10px !important}