/* ===== Book-appointment page — unified booker ===== */

.booker-hero{
  padding:36px 0 64px;
  background:linear-gradient(180deg,#fff 0%,var(--cream) 100%);
}
.booker-intro{max-width:760px;margin-bottom:26px}
.booker-intro h1{
  font-family:var(--f-display);font-weight:500;
  font-size:clamp(2.2rem,5vw,3.4rem);line-height:1.05;letter-spacing:-.02em;
  color:var(--ink);margin:8px 0 14px;
}
.booker-intro h1 em{font-style:italic;color:var(--teal);font-weight:500}
.booker-intro .lead{font-size:1.08rem;color:var(--ink-2);line-height:1.55;max-width:640px}

/* Trust band */
.booker-trust{
  display:grid;grid-template-columns:repeat(5,1fr);gap:14px;
  margin-bottom:28px;padding:20px 24px;
  background:#fff;border:1px solid var(--line-2);border-radius:var(--radius);
  box-shadow:var(--shadow-sm);
}
@media(max-width:720px){
  .booker-trust{grid-template-columns:repeat(3,1fr)}
  .booker-trust .bt-stat:nth-child(n+4){display:none}
}
@media(max-width:440px){.booker-trust{grid-template-columns:repeat(2,1fr)}
  .booker-trust .bt-stat:nth-child(n+3){display:none}
}
.bt-stat{display:flex;flex-direction:column;gap:2px;padding:0 8px;border-right:1px solid var(--line-2)}
.bt-stat:last-child{border-right:none}
.bt-stat strong{
  font-family:var(--f-display);font-weight:500;font-size:1.35rem;color:var(--teal);
  letter-spacing:-.01em;line-height:1;
}
.bt-stat span{font-size:.74rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-top:6px}

/* ── Main booker card ─────────────────────────────────────────────────── */
.booker-card{
  background:#fff;border:1px solid var(--line-2);
  border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);
  overflow:hidden;
}

.bk-step{padding:32px 36px;border-bottom:1px solid var(--line-2)}
.bk-step:last-of-type{border-bottom:none}
@media(max-width:640px){.bk-step{padding:24px 20px}}

.bk-step-hd{
  display:grid;grid-template-columns:40px 1fr;gap:16px;align-items:start;
  margin-bottom:20px;
}
.bk-num{
  display:flex;align-items:center;justify-content:center;
  width:40px;height:40px;border-radius:50%;
  background:var(--teal);color:#fff;
  font-family:var(--f-display);font-weight:500;font-size:1.1rem;
  letter-spacing:-.01em;
}
.bk-step-hd h3{
  font-family:var(--f-display);font-weight:500;font-size:1.3rem;
  color:var(--ink);letter-spacing:-.01em;margin:0 0 4px;line-height:1.2;
}
.bk-step-hd .sub{font-size:.88rem;color:var(--muted);margin:0;line-height:1.45}

/* Meeting type grid */
.bk-types{
  display:grid;grid-template-columns:1fr 1fr;gap:12px;
}
@media(max-width:700px){.bk-types{grid-template-columns:1fr}}
.bk-type{
  display:grid;grid-template-columns:44px 1fr;gap:14px;align-items:center;
  padding:16px 18px;
  background:var(--cream);border:2px solid transparent;border-radius:12px;
  text-align:left;cursor:pointer;transition:.18s;
  font-family:inherit;color:var(--ink);
}
.bk-type:hover{background:#fff;border-color:rgba(46,196,212,.3);transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.bk-type.active{
  background:#fff;border-color:var(--teal);
  box-shadow:0 0 0 4px rgba(46,196,212,.12),var(--shadow-sm);
}
.bk-type-ico{
  width:44px;height:44px;border-radius:10px;
  background:rgba(46,196,212,.12);color:var(--teal);
  display:flex;align-items:center;justify-content:center;
  transition:.18s;
}
.bk-type.active .bk-type-ico{background:var(--teal);color:#fff}
.bk-type-body{display:flex;flex-direction:column;gap:2px;min-width:0}
.bk-type-body strong{
  font-family:var(--f-body);font-size:.98rem;font-weight:600;color:var(--ink);
}
.bk-type-body small{font-size:.82rem;color:var(--muted);line-height:1.4}

/* Format picker */
.bk-formats{
  display:grid;grid-template-columns:repeat(4,1fr);gap:10px;
}
@media(max-width:600px){.bk-formats{grid-template-columns:repeat(2,1fr)}}
.bk-fmt{
  display:flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 16px;
  background:var(--cream);border:2px solid transparent;border-radius:10px;
  cursor:pointer;transition:.18s;
  font-family:inherit;font-size:.92rem;font-weight:500;color:var(--ink);
}
.bk-fmt:hover{background:#fff;border-color:rgba(46,196,212,.3)}
.bk-fmt.active{
  background:#fff;border-color:var(--teal);color:var(--teal);
  box-shadow:0 0 0 3px rgba(46,196,212,.1);
}
.bk-fmt svg{opacity:.7;flex-shrink:0}
.bk-fmt.active svg{opacity:1}

/* Calendar */
.bk-cal{
  background:var(--cream);border-radius:14px;padding:22px 22px 26px;
  border:1px solid var(--line-2);
}
@media(max-width:640px){.bk-cal{padding:18px 14px}}
.bk-cal-nav{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  margin-bottom:14px;
}
.bk-cal-nav button{
  width:36px;height:36px;border-radius:8px;
  background:#fff;border:1px solid var(--line-2);
  font-size:1.3rem;color:var(--ink);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:.15s;
}
.bk-cal-nav button:hover:not(:disabled){background:var(--teal);color:#fff;border-color:var(--teal)}
.bk-cal-nav button:disabled{opacity:.3;cursor:not-allowed}
.bk-cal-week{
  font-family:var(--f-display);font-weight:500;font-size:1.02rem;color:var(--ink);
  letter-spacing:-.01em;
}

.bk-cal-days{
  display:grid;grid-template-columns:repeat(7,1fr);gap:8px;margin-bottom:22px;
}
@media(max-width:640px){.bk-cal-days{grid-template-columns:repeat(4,1fr)}
  .bk-cal-days .bk-day:nth-child(n+5){display:none}
}
.bk-day{
  display:flex;flex-direction:column;align-items:center;gap:2px;
  padding:14px 6px 12px;background:#fff;
  border:2px solid transparent;border-radius:10px;
  cursor:pointer;transition:.15s;
  font-family:inherit;color:var(--ink);
}
.bk-day:hover:not(:disabled):not(.selected){border-color:rgba(46,196,212,.35);transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.bk-day.selected{
  background:var(--teal);border-color:var(--teal);color:#fff;
  box-shadow:0 0 0 4px rgba(46,196,212,.15);
}
.bk-day.closed{opacity:.45;cursor:not-allowed;background:#f8f8f8}
.bk-day-dow{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;font-weight:600;color:var(--muted)}
.bk-day.selected .bk-day-dow{color:rgba(255,255,255,.85)}
.bk-day-num{font-family:var(--f-display);font-weight:500;font-size:1.55rem;line-height:1;color:var(--ink);letter-spacing:-.01em}
.bk-day.selected .bk-day-num{color:#fff}
.bk-day-mo{font-size:.7rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-top:1px}
.bk-day.selected .bk-day-mo{color:rgba(255,255,255,.85)}
.bk-day-slots{font-size:.7rem;color:var(--teal);font-weight:600;margin-top:6px}
.bk-day.selected .bk-day-slots{color:#fff}
.bk-day.closed .bk-day-slots{color:var(--muted)}

/* Time slots */
.bk-cal-times{min-height:100px}
.bk-empty{
  text-align:center;color:var(--muted);font-size:.9rem;
  padding:30px 20px;font-style:italic;
}
.bk-time-hd{
  display:flex;align-items:baseline;justify-content:space-between;
  padding-bottom:12px;margin-bottom:14px;
  border-bottom:1px dashed var(--line-2);
}
.bk-time-hd strong{
  font-family:var(--f-display);font-weight:500;font-size:1.05rem;color:var(--ink);
}
.bk-time-hd span{font-size:.8rem;color:var(--muted)}
.bk-time-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:10px;
}
@media(max-width:600px){.bk-time-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:400px){.bk-time-grid{grid-template-columns:repeat(2,1fr)}}
.bk-time{
  padding:12px 8px;background:#fff;
  border:2px solid var(--line-2);border-radius:8px;
  font-family:inherit;font-size:.92rem;font-weight:500;color:var(--ink);
  cursor:pointer;transition:.15s;
  text-align:center;
}
.bk-time:hover{border-color:var(--teal);color:var(--teal)}
.bk-time.selected{
  background:var(--teal);color:#fff;border-color:var(--teal);
  box-shadow:0 0 0 3px rgba(46,196,212,.15);
}

/* Form */
.bk-form{
  display:grid;grid-template-columns:repeat(3,1fr);gap:14px;
}
@media(max-width:700px){.bk-form{grid-template-columns:1fr 1fr}
  .bk-field-full{grid-column:1/-1}}
@media(max-width:480px){.bk-form{grid-template-columns:1fr}}
.bk-field-full{grid-column:1/-1}
.bk-field{display:flex;flex-direction:column;gap:6px}
.bk-field label{
  font-size:.78rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-weight:600;
}
.bk-field input,.bk-field textarea{
  padding:11px 14px;background:var(--cream);
  border:1px solid var(--line-2);border-radius:8px;
  font-family:inherit;font-size:.95rem;color:var(--ink);
  transition:.15s;resize:vertical;
}
.bk-field input:focus,.bk-field textarea:focus{
  outline:none;border-color:var(--teal);background:#fff;
  box-shadow:0 0 0 3px rgba(46,196,212,.12);
}

/* Confirm bar */
.bk-confirm{
  padding:28px 36px 32px;
  background:linear-gradient(135deg,#0A1F3A 0%,#102a52 100%);
  color:#fff;
}
@media(max-width:640px){.bk-confirm{padding:22px 20px 26px}}
.bk-summary{
  display:grid;grid-template-columns:repeat(3,1fr);gap:16px;
  padding:16px 20px;margin-bottom:18px;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.12);border-radius:10px;
}
@media(max-width:640px){.bk-summary{grid-template-columns:1fr;gap:10px}}
.bk-sum-row{display:flex;flex-direction:column;gap:3px;min-width:0}
.bk-sum-row span{
  font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;
  color:rgba(255,255,255,.6);font-weight:600;
}
.bk-sum-row strong{
  font-family:var(--f-display);font-weight:500;font-size:1rem;color:#fff;
  letter-spacing:-.01em;line-height:1.25;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.bk-actions{
  display:flex;flex-wrap:wrap;gap:10px;margin-bottom:12px;
}
.bk-confirm-btn{opacity:.55;pointer-events:none;transition:.2s}
.bk-confirm.ready .bk-confirm-btn{opacity:1;pointer-events:auto}
/* A confirm button can be individually disabled (e.g. primary needs name + mobile) even once a time is picked */
.bk-confirm.ready .bk-confirm-btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:none;transform:none}
.bk-confirm .btn-ghost{
  background:transparent;border:1px solid rgba(255,255,255,.3);color:#fff;
}
.bk-confirm .btn-ghost:hover{background:rgba(255,255,255,.1);border-color:#fff}
.bk-note{
  font-size:.82rem;color:rgba(255,255,255,.65);line-height:1.5;
  margin:0;font-style:italic;
}

/* "What to bring" cards (kept from before) */
.bring-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:32px;
}
@media(max-width:900px){.bring-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:500px){.bring-grid{grid-template-columns:1fr}}

.bring-card{
  background:#fff;border:1px solid var(--line-2);
  border-radius:var(--radius);padding:22px 20px;
  box-shadow:var(--shadow-sm);transition:.2s;
}
.bring-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:rgba(46,196,212,.3)}
.bring-card h3{
  font-family:var(--f-display);font-weight:500;font-size:1.12rem;
  color:var(--ink);letter-spacing:-.01em;margin-bottom:14px;
  padding-bottom:12px;border-bottom:1px dashed var(--line-2);
}
.bring-card ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.bring-card li{
  padding-left:20px;position:relative;
  font-size:.88rem;color:var(--ink-2);line-height:1.5;
}
.bring-card li::before{
  content:'';position:absolute;left:0;top:7px;
  width:10px;height:6px;
  border-left:2px solid var(--teal);border-bottom:2px solid var(--teal);
  transform:rotate(-45deg);
}
