/* ===== Booking widget ===== */
.book{padding:90px 0;background:linear-gradient(180deg,var(--blue-soft),#fff)}
.booking{
  max-width:920px;margin:0 auto;background:#fff;border:1px solid var(--line);
  border-radius:22px;box-shadow:var(--shadow);overflow:hidden;
}
.booking-step{padding:30px 32px;border-bottom:1px solid var(--line)}
.booking-step:last-child{border-bottom:0}
.booking-step h3{font-family:"Archivo",sans-serif;font-size:1.05rem;color:var(--navy);display:flex;align-items:center;gap:12px;margin:0 0 18px}
.step-num{
  display:grid;place-items:center;width:28px;height:28px;border-radius:50%;
  background:var(--blue);color:#fff;font-size:.85rem;font-weight:700;flex:none;
}

/* service cards */
.svc-options{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.svc-option{
  text-align:left;background:var(--off);border:2px solid var(--line);border-radius:14px;
  padding:18px 20px;cursor:pointer;transition:.18s;font-family:inherit;
}
.svc-option:hover{border-color:var(--blue-light)}
.svc-option.selected{border-color:var(--blue);background:#fff;box-shadow:0 0 0 4px rgba(30,111,224,.12)}
.svc-option .svc-name{display:block;font-family:"Archivo",sans-serif;font-weight:700;color:var(--navy);font-size:1.05rem}
.svc-option .svc-dur{display:block;color:var(--muted);font-size:.9rem;margin-top:4px}

/* date + slots */
.book-date{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.book-date label{font-family:"Archivo",sans-serif;font-weight:600;color:var(--navy);font-size:.92rem}
.book-date input[type=date]{
  padding:12px 14px;border:1px solid var(--line);border-radius:11px;font:inherit;
  background:var(--off);color:var(--navy);
}
.book-date input[type=date]:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 4px rgba(30,111,224,.12)}
.book-tz{color:var(--muted);font-size:.85rem}

.slots{margin-top:18px;display:grid;grid-template-columns:repeat(auto-fill,minmax(104px,1fr));gap:10px}
.slot{
  padding:11px 8px;border:1.5px solid var(--line);border-radius:10px;background:#fff;
  font-family:"Archivo",sans-serif;font-weight:600;color:var(--navy);cursor:pointer;transition:.15s;font-size:.92rem;
}
.slot:hover{border-color:var(--blue);color:var(--blue)}
.slot.selected{background:var(--blue);border-color:var(--blue);color:#fff}
.slots-msg{color:var(--muted);font-size:.95rem;padding:8px 0}
.slots-msg.error{color:#c0392b}

/* details */
.book-fields{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.book-fields .field{margin:0}
.book-fields .field.full{grid-column:1 / -1}
.book-field-hint{grid-column:1/-1;color:var(--muted);font-size:.85rem;margin:-4px 0 0}

.booking-footer{padding:24px 32px;background:var(--off);display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.booking-summary{font-size:.95rem;color:var(--navy)}
.booking-summary strong{color:var(--blue)}
.booking-footer .btn:disabled{opacity:.5;cursor:not-allowed;transform:none}

/* confirmation */
.booking-done{padding:48px 32px;text-align:center}
.booking-done .check{
  width:64px;height:64px;border-radius:50%;background:var(--blue);color:#fff;
  display:grid;place-items:center;margin:0 auto 18px;
}
.booking-done .check svg{width:32px;height:32px}
.booking-done h3{font-family:"Anton",sans-serif;font-weight:400;text-transform:uppercase;font-size:1.8rem;color:var(--navy);margin:0 0 10px}
.booking-done p{color:var(--muted);max-width:460px;margin:0 auto 8px}
.booking-done .when{font-family:"Archivo",sans-serif;font-weight:700;color:var(--blue);font-size:1.15rem}

.booking-unavailable{padding:30px 32px;color:var(--muted)}
.booking-unavailable a{color:var(--blue);font-weight:600}

@media (max-width:680px){
  .svc-options{grid-template-columns:1fr}
  .book-fields{grid-template-columns:1fr}
  .booking-step{padding:24px 20px}
  .booking-footer{padding:20px}
}
