/* =========================================================
   Conseil Bien-Être — Styles du module RDV (réservation + admin)
   S'appuie sur les variables :root de style.css (--sage, --cta…)
   ========================================================= */

.booking { background:#fff; border:1px solid rgba(124,152,133,.16); border-radius:var(--radius); box-shadow:var(--shadow); padding:30px; }
.hidden { display:none !important; }
.bk-h2 { font-family:var(--font-head); color:var(--deep-green); font-size:1.4rem; margin-bottom:6px; }
.bk-muted { color:var(--grey); font-size:.95rem; margin-bottom:18px; }

/* Stepper */
.bk-steps { display:flex; gap:10px; margin-bottom:26px; flex-wrap:wrap; }
.bk-step { display:flex; align-items:center; gap:10px; flex:1; min-width:160px; padding:12px 14px; border-radius:var(--radius-sm); background:var(--cream); opacity:.6; transition:.2s; }
.bk-step.is-active { opacity:1; background:#fff; box-shadow:var(--shadow); border:1px solid rgba(124,152,133,.2); }
.bk-step.is-done { opacity:1; }
.bk-step-num { width:32px; height:32px; flex:0 0 auto; border-radius:50%; background:var(--sage-light); color:#fff; font-weight:700; display:grid; place-items:center; }
.bk-step.is-active .bk-step-num { background:var(--cta); }
.bk-step.is-done .bk-step-num { background:var(--eucalyptus); }
.bk-step-text { display:flex; flex-direction:column; line-height:1.2; }
.bk-step-text b { color:var(--deep-green); font-size:.95rem; }
.bk-step-text small { color:var(--grey); font-size:.78rem; }

/* Formulaire */
.bk-row2 { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.bk-field { margin-bottom:16px; }
.bk-label { display:block; font-weight:600; color:var(--deep-green); font-size:.9rem; margin-bottom:6px; }
.bk-req { color:var(--cta-dark); }
.bk-opt { color:var(--grey); font-weight:400; font-size:.82rem; }
.bk-input { width:100%; padding:12px 14px; border:1.5px solid #d8e0d8; border-radius:var(--radius-sm); font-family:inherit; font-size:1rem; color:var(--charcoal); background:#fff; transition:border-color .2s; }
.bk-input:focus { outline:none; border-color:var(--sage); }
.bk-textarea { resize:vertical; min-height:80px; }
.bk-invalid { border-color:#d9534f !important; background:#fdf2f2; }
select.bk-input { appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%237c9885' d='M6 8 0 0h12z'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 16px center; padding-right:38px; }

.bk-info { display:flex; gap:10px; align-items:flex-start; background:#eef3ee; border:1px solid rgba(124,152,133,.25); border-radius:var(--radius-sm); padding:14px 16px; font-size:.9rem; color:#3c453d; margin:6px 0 18px; }

.bk-actions-row { display:flex; justify-content:space-between; gap:12px; margin-top:24px; flex-wrap:wrap; }
.btn:disabled { opacity:.5; cursor:not-allowed; }
.bk-icon { padding:10px 16px !important; font-size:1.2rem; line-height:1; }

/* Calendrier */
.bk-cal-toolbar { display:flex; align-items:center; justify-content:space-between; gap:12px; margin:14px 0; flex-wrap:wrap; }
.bk-cal-nav { display:flex; gap:8px; }
.bk-week-label { font-family:var(--font-head); font-weight:600; color:var(--deep-green); }

.bk-grid { display:grid; grid-template-columns:64px repeat(7,1fr); gap:4px; }
.bk-cell { min-height:42px; display:flex; align-items:center; justify-content:center; font-size:.82rem; border-radius:8px; }
.bk-hour { color:var(--grey); font-size:.72rem; justify-content:flex-end; padding-right:6px; background:transparent; }
.bk-corner { background:transparent; }
.bk-head { flex-direction:column; background:var(--cream); color:var(--deep-green); font-weight:600; padding:6px 0; line-height:1.1; }
.bk-head-day { font-size:.72rem; text-transform:uppercase; letter-spacing:.04em; }
.bk-head-num { font-size:1.05rem; font-weight:700; }
.bk-head.bk-today { background:var(--sage); color:#fff; }
.bk-weekend { background:#f1efe9; }
.bk-oor { background:#f6f5f2; color:#c8ccc6; }

.bk-slot { background:#f3f1eb; color:transparent; user-select:none; }
.bk-slot.is-busy { background:#f1efe9; }
.bk-slot.is-free { background:#e4efe5; color:var(--deep-green); font-weight:600; cursor:pointer; border:1.5px solid transparent; transition:.15s; }
.bk-slot.is-free:hover { background:var(--sage); color:#fff; transform:translateY(-1px); }
.bk-slot.is-selected { background:var(--cta) !important; color:#fff !important; border-color:var(--cta-dark); box-shadow:0 4px 12px var(--cta-glow); }

/* Légende */
.bk-legend { display:flex; gap:18px; flex-wrap:wrap; align-items:center; margin:16px 0; font-size:.85rem; color:var(--grey); }
.bk-legend-item { display:flex; align-items:center; gap:7px; }
.bk-sw { width:16px; height:16px; border-radius:5px; display:inline-block; }
.bk-sw-free { background:#e4efe5; border:1.5px solid var(--sage); }
.bk-sw-busy { background:#f1efe9; }
.bk-sw-avail { background:var(--sage); }
.bk-sw-booked { background:var(--eucalyptus); }

/* Récap */
.bk-recap { border:1px solid rgba(124,152,133,.2); border-radius:var(--radius-sm); overflow:hidden; }
.bk-recap-head { display:flex; justify-content:space-between; align-items:center; gap:10px; flex-wrap:wrap; padding:16px 18px; background:var(--cream); }
.bk-recap-head strong { font-family:var(--font-head); color:var(--deep-green); font-size:1.05rem; }
.bk-recap-grid { display:grid; grid-template-columns:1fr 1fr; gap:14px; padding:18px; }
.bk-recap-grid > div { display:flex; flex-direction:column; }
.bk-recap-grid span { font-size:.72rem; text-transform:uppercase; letter-spacing:.04em; color:var(--grey); margin-bottom:2px; }
.bk-recap-grid b { color:var(--charcoal); }
.bk-recap-full { grid-column:1 / -1; }

/* Succès */
.bk-success { text-align:center; padding:10px; }
.bk-check { width:72px; height:72px; border-radius:50%; background:var(--eucalyptus); color:#fff; font-size:2rem; display:grid; place-items:center; margin:0 auto 16px; }
.bk-detail { max-width:420px; margin:18px auto; text-align:left; border:1px solid rgba(124,152,133,.2); border-radius:var(--radius-sm); padding:8px 18px; }
.bk-row { display:flex; justify-content:space-between; gap:12px; padding:10px 0; border-bottom:1px dashed rgba(124,152,133,.25); }
.bk-row:last-child { border-bottom:none; }
.bk-row span { color:var(--grey); }
.bk-row b { color:var(--deep-green); }

.bk-meet { background:#eef3ee; border:1px solid rgba(124,152,133,.3); border-radius:var(--radius-sm); padding:18px; margin:16px auto; max-width:560px; text-align:left; }
.bk-meet-head { margin-bottom:12px; color:var(--deep-green); }
.bk-meet-row { display:flex; gap:8px; flex-wrap:wrap; }
.bk-meet-row input { flex:1; min-width:180px; padding:10px 12px; border:1px solid #d8e0d8; border-radius:10px; font-size:.85rem; }
.bk-agenda { margin:18px auto 0; max-width:560px; text-align:left; }
.bk-agenda-btns { display:flex; gap:10px; flex-wrap:wrap; margin-top:10px; }

/* Toast */
.bk-toast-area { position:fixed; bottom:24px; right:24px; display:flex; flex-direction:column; gap:10px; z-index:1000; }
.bk-toast { background:#fff; border-left:4px solid var(--sage); box-shadow:var(--shadow-lg); padding:14px 18px; border-radius:10px; font-size:.9rem; color:var(--charcoal); transition:.4s; max-width:320px; }
.bk-toast.success { border-left-color:var(--eucalyptus); }
.bk-toast.error { border-left-color:#d9534f; }

/* ============ Back-office ============ */
.adm-nav { background:var(--deep-green-d); color:#fff; padding:14px 0; }
.adm-nav .container { display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap; }
.adm-brand { display:flex; align-items:center; gap:10px; color:#fff; font-family:var(--font-head); font-size:1.1rem; }
.adm-brand .brand__mark { width:34px; height:34px; }
.adm-links { display:flex; gap:8px; align-items:center; flex-wrap:wrap; }
.adm-link { color:rgba(255,255,255,.85); padding:8px 14px; border-radius:100px; font-size:.9rem; font-weight:500; }
.adm-link:hover, .adm-link.active { background:rgba(255,255,255,.14); color:#fff; }
.adm-main { padding:34px 0; }
.adm-card { background:#fff; border:1px solid rgba(124,152,133,.16); border-radius:var(--radius); box-shadow:var(--shadow); padding:24px; margin-bottom:24px; }
.adm-title { font-family:var(--font-head); color:var(--deep-green); font-size:1.6rem; margin-bottom:4px; }

.gcal-banner { display:flex; align-items:center; gap:16px; padding:16px 20px; border-radius:var(--radius); margin-bottom:22px; }
.gcal-ok { background:#e7f1e8; border:1px solid rgba(95,125,110,.3); }
.gcal-ko { background:#fff3e9; border:1px solid rgba(217,130,72,.35); }
.gcal-banner .g-ico { font-size:1.6rem; }
.gcal-banner .g-txt { flex:1; }
.gcal-banner .g-txt strong { display:block; color:var(--deep-green); }
.gcal-banner .g-txt span { font-size:.88rem; color:var(--grey); }

.adm-toolbar { display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:14px; flex-wrap:wrap; }
.adm-slot { background:#f3f1eb; cursor:pointer; }
.adm-slot.is-available { background:var(--sage); color:#fff; font-weight:600; }
.adm-slot.is-available::after { content:"Dispo"; font-size:.72rem; }
.adm-slot.is-booked { background:var(--eucalyptus); color:#fff; font-weight:600; cursor:pointer; font-size:.74rem; padding:2px; text-align:center; }
.adm-slot.is-dragging-on { background:var(--sage); opacity:.7; }
.adm-slot.is-dragging-off { background:#f3f1eb; opacity:.7; }
.adm-slot.bk-oor { cursor:default; }

/* Modale */
.modal-bd { position:fixed; inset:0; background:rgba(44,63,53,.5); display:none; place-items:center; z-index:1100; padding:20px; }
.modal-bd.open { display:grid; }
.modal { background:#fff; border-radius:var(--radius); max-width:520px; width:100%; box-shadow:var(--shadow-lg); overflow:hidden; }
.modal-h { display:flex; justify-content:space-between; align-items:center; padding:18px 22px; border-bottom:1px solid rgba(124,152,133,.18); }
.modal-h h3 { font-family:var(--font-head); color:var(--deep-green); font-size:1.15rem; }
.modal-b { padding:22px; }
.modal-f { display:flex; justify-content:space-between; gap:10px; padding:16px 22px; border-top:1px solid rgba(124,152,133,.18); }
.modal-x { background:none; border:none; font-size:1.4rem; cursor:pointer; color:var(--grey); }
.kv { margin-bottom:8px; } .kv span { color:var(--grey); font-size:.8rem; text-transform:uppercase; letter-spacing:.04em; } .kv b { display:block; color:var(--charcoal); }
.btn--danger { background:#d9534f; color:#fff; }
.btn--danger:hover { background:#c44440; color:#fff; }

/* Liste RDV (récap) */
.rdv-list { display:flex; flex-direction:column; gap:12px; }
.rdv-item { display:flex; gap:16px; align-items:flex-start; border:1px solid rgba(124,152,133,.18); border-radius:var(--radius-sm); padding:16px 18px; }
.rdv-when { flex:0 0 130px; font-family:var(--font-head); color:var(--deep-green); font-weight:600; }
.rdv-when small { display:block; color:var(--grey); font-family:var(--font-body); font-weight:400; font-size:.82rem; }
.rdv-who b { color:var(--charcoal); } .rdv-who div { font-size:.88rem; color:var(--grey); }
.rdv-tag { display:inline-block; background:var(--cream); color:var(--eucalyptus); font-size:.78rem; font-weight:600; padding:3px 10px; border-radius:100px; margin-top:4px; }

/* ============ Journal de consultations ============ */
.consult-list { display:flex; flex-direction:column; gap:14px; margin-top:8px; }
.consult-item { border:1px solid rgba(124,152,133,.22); border-left:4px solid var(--eucalyptus); border-radius:var(--radius-sm); overflow:hidden; }
.consult-head { display:flex; justify-content:space-between; align-items:center; gap:10px; background:var(--cream); padding:10px 16px; }
.consult-head strong { font-family:var(--font-head); color:var(--deep-green); }
.consult-del { background:none; border:none; color:#c0392b; font-size:1rem; cursor:pointer; line-height:1; padding:4px 8px; border-radius:6px; }
.consult-del:hover { background:#fdecec; }
.consult-body { padding:14px 18px; color:#3c453d; line-height:1.65; }
.consult-body h1,.consult-body h2,.consult-body h3 { font-family:var(--font-head); color:var(--deep-green); margin:.4em 0; }
.consult-body ul,.consult-body ol { margin:.4em 0 .4em 1.4em; }
.consult-body table { border-collapse:collapse; margin:.5em 0; }
.consult-body td,.consult-body th { border:1px solid rgba(124,152,133,.3); padding:6px 10px; }
.consult-body p { margin-bottom:.5em; }

/* ============ Pré-audit ============ */
.bk-fieldset { border:1px solid rgba(124,152,133,.2); border-radius:var(--radius); padding:18px 20px 6px; margin:0 0 22px; }
.bk-legend-title { font-family:var(--font-head); color:var(--deep-green); font-weight:600; font-size:1.15rem; padding:0 8px; }
.bk-form-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-top:8px; }
.bk-field-wide { grid-column:1 / -1; }
.bk-check-grid { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:4px 22px; }
.bk-pick { display:flex; align-items:center; gap:10px; padding:7px 8px; border-radius:8px; font-size:.92rem; line-height:1.3; color:var(--charcoal); cursor:pointer; }
.bk-pick span { color:var(--charcoal); }
.bk-pick input { flex:0 0 auto; width:17px; height:17px; accent-color:var(--eucalyptus); cursor:pointer; }
.bk-pick:hover { background:var(--cream); }
@media (max-width:760px){ .bk-check-grid { grid-template-columns:1fr; } }
.bk-scale { display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.bk-scale-end { color:var(--grey); font-size:.82rem; }
.bk-scale-opt { display:inline-flex; flex-direction:column; align-items:center; gap:3px; cursor:pointer; }
.bk-scale-opt input { accent-color:var(--cta); width:20px; height:20px; }
.bk-scale-opt span { font-size:.8rem; color:var(--grey); }

.bk-imc { display:flex; align-items:center; gap:14px; justify-content:center; background:linear-gradient(135deg,var(--cream),#fff); border:1px solid rgba(124,152,133,.25); border-radius:var(--radius); padding:16px 22px; margin:8px 0 4px; flex-wrap:wrap; }
.bk-imc span { color:var(--grey); font-size:.9rem; }
.bk-imc strong { font-family:var(--font-head); font-size:2rem; color:var(--deep-green); }
.bk-imc em { font-style:normal; font-weight:600; color:var(--cta-dark); background:#fff3e9; padding:4px 12px; border-radius:100px; font-size:.9rem; }

.bk-audit-cta { display:flex; gap:16px; align-items:flex-start; background:linear-gradient(135deg,#fff7f1,#fdeee2); border:1.5px solid rgba(217,130,72,.4); border-radius:var(--radius); padding:20px; margin:16px auto; max-width:560px; text-align:left; }
.bk-audit-ico { font-size:2rem; }
.bk-audit-txt strong { display:block; color:var(--deep-green); font-family:var(--font-head); font-size:1.1rem; margin-bottom:4px; }
.bk-audit-txt p { color:var(--grey); font-size:.9rem; margin-bottom:12px; }

@media (max-width:760px){
  .bk-row2, .bk-recap-grid, .bk-form-grid { grid-template-columns:1fr; }
  .bk-grid { grid-template-columns:46px repeat(7,1fr); gap:3px; }
  .bk-cell { min-height:38px; font-size:.7rem; }
  .booking { padding:18px; }
  .rdv-item { flex-direction:column; gap:6px; }
}
