/* Wizard styles — iOS-inspired booking flow
   Scoped under .prv-wz to avoid collisions with site.css */

.prv-wz{
  --wz-ink:#0F172A; --wz-ink-2:#334155; --wz-mute:#64748B; --wz-faint:#94A3B8;
  --wz-line:#E2E8F0; --wz-surface:#F8FAFC; --wz-chip:#F1F5F9; --wz-border:#CBD5E1;
  --wz-ok:#047857; --wz-ok-bg:#D1FAE5; --wz-ok-border:#86EFAC;
  --wz-err:#DC2626; --wz-err-bg:#FEF2F2; --wz-err-border:#FCA5A5;
  --wz-warn:#F59E0B;
  font-family:'Geist',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  color:var(--wz-ink);
  background:#fff;
  max-width:560px;
  margin:0 auto;
  min-height:600px;
  display:flex;
  flex-direction:column;
  border:1px solid var(--wz-line);
  border-radius:20px;
  overflow:hidden;
  box-shadow:0 4px 20px rgba(15,23,42,.06);
}
@media (max-width:640px){
  .prv-wz{border-radius:16px;min-height:560px}
}

/* Progress bar */
.prv-wz-progress{
  padding:14px 18px 16px;background:#fff;border-bottom:1px solid #F1F5F9;
  position:sticky;top:0;z-index:10;
}
.prv-wz-progress-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.prv-wz-iconbtn{
  width:36px;height:36px;border-radius:10px;border:0;background:var(--wz-chip);
  display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--wz-ink);
  transition:all 150ms;
}
.prv-wz-iconbtn[disabled]{background:transparent;color:var(--wz-border);cursor:default}
.prv-wz-stepnum{font-size:13px;font-weight:500;color:var(--wz-mute)}
.prv-wz-bar{height:4px;background:#F1F5F9;border-radius:999px;overflow:hidden}
.prv-wz-bar-fill{height:100%;background:var(--wz-ink);border-radius:999px;transition:width 400ms cubic-bezier(.2,.8,.2,1)}

/* Scroll area */
.prv-wz-body{flex:1;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;-webkit-overflow-scrolling:touch}
.prv-wz-body.slide-in{animation:wzSlideIn 280ms cubic-bezier(.2,.8,.2,1)}
.prv-wz-body.slide-back{animation:wzSlideBack 280ms cubic-bezier(.2,.8,.2,1)}
@keyframes wzSlideIn{from{opacity:0;transform:translateX(16px)}to{opacity:1;transform:translateX(0)}}
@keyframes wzSlideBack{from{opacity:0;transform:translateX(-16px)}to{opacity:1;transform:translateX(0)}}
@keyframes wzSpin{to{transform:rotate(360deg)}}
@keyframes wzPop{from{transform:scale(.6);opacity:0}to{transform:scale(1);opacity:1}}

.prv-wz-step{padding:24px 18px 8px;flex:1;display:flex;flex-direction:column}
.prv-wz-h1{font-size:26px;font-weight:700;color:var(--wz-ink);margin:0;letter-spacing:-.02em;line-height:1.15}
.prv-wz-sub{font-size:15px;color:var(--wz-mute);margin:8px 0 20px;line-height:1.45}

/* Cards */
.prv-wz-list{display:flex;flex-direction:column;gap:10px}
.prv-wz-card{
  background:#fff;border:1.5px solid var(--wz-line);border-radius:14px;padding:16px;
  cursor:pointer;transition:all 180ms cubic-bezier(.2,.8,.2,1);position:relative;
  text-align:left;font-family:inherit;color:inherit;width:100%;
}
.prv-wz-card.selected{border-color:var(--wz-ink);box-shadow:0 0 0 3px rgba(15,23,42,.06)}

.prv-wz-device{display:flex;align-items:center;gap:16px;padding:18px}
.prv-wz-device-icon{
  width:52px;height:52px;border-radius:12px;background:var(--wz-chip);color:var(--wz-ink);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all 180ms;
}
.prv-wz-card.selected .prv-wz-device-icon{background:var(--wz-ink);color:#fff}
.prv-wz-device-title{font-size:17px;font-weight:600;letter-spacing:-.01em}
.prv-wz-device-sub{font-size:13px;color:var(--wz-mute);margin-top:2px}

.prv-wz-infobox{
  margin-top:24px;padding:14px 16px;background:var(--wz-surface);border-radius:12px;
  display:flex;gap:12px;align-items:flex-start;
}
.prv-wz-infobox-icon{
  width:32px;height:32px;border-radius:8px;background:var(--wz-ink);color:#fff;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}

/* Search input */
.prv-wz-search{position:relative;margin-bottom:18px}
.prv-wz-search input{
  width:100%;padding:12px 14px 12px 42px;font-size:15px;font-family:inherit;
  background:var(--wz-surface);border:1.5px solid transparent;border-radius:10px;
  outline:none;box-sizing:border-box;
}
.prv-wz-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--wz-faint);pointer-events:none}

.prv-wz-yeargroup{margin-bottom:18px}
.prv-wz-kicker{
  font-size:11.5px;font-weight:600;color:var(--wz-faint);
  text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px;padding-left:2px;
}
.prv-wz-modelbtn{
  width:100%;padding:14px 16px;background:#fff;color:var(--wz-ink);
  border:1.5px solid var(--wz-line);border-radius:12px;font-size:15px;font-weight:500;
  font-family:inherit;text-align:left;cursor:pointer;transition:all 150ms;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
}

/* Series-cards (sub-stap 1 van model-step) */
.prv-wz-series{display:flex;align-items:center;justify-content:space-between;padding:18px}
.prv-wz-series-row{flex:1}
.prv-wz-series-title{font-size:17px;font-weight:600;color:var(--wz-ink);letter-spacing:-.01em}
.prv-wz-series-sub{font-size:13px;color:var(--wz-mute);margin-top:2px}

/* Sub-stap-terug-link binnen model-step */
.prv-wz-substep-back{margin-bottom:8px}
.prv-wz-backlink{
  display:inline-flex;align-items:center;gap:4px;padding:6px 10px;font-size:12.5px;
  background:var(--wz-chip);color:var(--wz-ink-2);border:0;border-radius:8px;
  cursor:pointer;font-family:inherit;font-weight:500;
}
.prv-wz-backlink:hover{background:#E2E8F0}
.prv-wz-modelbtn.selected{background:var(--wz-ink);color:#fff;border-color:var(--wz-ink)}
.prv-wz-modelgroup{display:flex;flex-direction:column;gap:6px}

/* Repair card */
.prv-wz-repair{padding:16px}
.prv-wz-repair-row{display:flex;gap:14px;align-items:flex-start}
.prv-wz-repair-icon{
  width:44px;height:44px;border-radius:10px;background:var(--wz-chip);color:var(--wz-ink);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all 180ms;
}
.prv-wz-card.selected .prv-wz-repair-icon{background:var(--wz-ink);color:#fff}
.prv-wz-repair-body{flex:1;min-width:0}
.prv-wz-repair-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px}
.prv-wz-repair-label{font-size:16px;font-weight:600}
.prv-wz-repair-price{font-size:16px;font-weight:700;white-space:nowrap}
.prv-wz-repair-desc{font-size:13.5px;color:var(--wz-mute);margin-top:3px;line-height:1.4}
.prv-wz-chips{display:flex;gap:6px;margin-top:10px;flex-wrap:wrap}
.prv-wz-chip{
  display:inline-flex;align-items:center;gap:4px;padding:3px 9px;font-size:11.5px;
  font-weight:600;letter-spacing:.01em;border-radius:999px;white-space:nowrap;
  background:var(--wz-chip);color:var(--wz-ink-2);
}
.prv-wz-chip.green{background:var(--wz-ok-bg);color:var(--wz-ok)}

/* Input */
.prv-wz-field{display:block}
.prv-wz-field-lbl{display:block;font-size:13px;font-weight:500;color:var(--wz-ink-2);margin-bottom:6px}
.prv-wz-input{
  width:100%;padding:14px 14px;font-size:16px;font-family:inherit;color:var(--wz-ink);
  background:#fff;border:1.5px solid var(--wz-line);border-radius:10px;
  outline:none;transition:all 150ms;box-sizing:border-box;min-height:50px;
}
.prv-wz-input:focus{border-color:var(--wz-ink)}
.prv-wz-input.err{border-color:var(--wz-err)}
.prv-wz-field-err{display:block;font-size:12.5px;color:var(--wz-err);margin-top:6px;font-weight:500}
.prv-wz-textarea{
  width:100%;padding:12px 14px;font-size:15px;font-family:inherit;color:var(--wz-ink);
  background:#fff;border:1.5px solid var(--wz-line);border-radius:10px;
  outline:none;resize:none;box-sizing:border-box;
}

.prv-wz-grid-2{display:grid;grid-template-columns:1.4fr 1fr;gap:10px}
.prv-wz-stack{display:flex;flex-direction:column;gap:14px}

/* Address result */
.prv-wz-addr-ok{
  padding:14px 16px;background:#F0FDF4;border-radius:12px;border:1.5px solid var(--wz-ok-border);
  display:flex;gap:12px;align-items:flex-start;
}
.prv-wz-addr-ok-icon{color:#15803D;flex-shrink:0;margin-top:1px}
.prv-wz-addr-ok-street{font-size:14px;font-weight:600;color:#14532D}
.prv-wz-addr-ok-pc{font-size:13px;color:#166534;margin-top:2px}
.prv-wz-addr-err{padding:14px 16px;background:var(--wz-err-bg);border-radius:12px;border:1.5px solid var(--wz-err-border)}
.prv-wz-addr-err-title{font-size:14px;font-weight:600;color:#991B1B;margin-bottom:2px}
.prv-wz-addr-err-desc{font-size:13px;color:#B91C1C;line-height:1.45}
.prv-wz-addr-checking{
  padding:12px 14px;background:var(--wz-surface);border-radius:10px;
  display:flex;align-items:center;gap:10px;font-size:13.5px;color:var(--wz-mute);
}
.prv-wz-spin{
  width:16px;height:16px;border-radius:50%;border:2px solid #CBD5E1;border-top-color:var(--wz-ink);
  animation:wzSpin 700ms linear infinite;
}

/* Date scroller */
.prv-wz-dates{
  display:flex;gap:8px;overflow-x:auto;padding:4px 18px 16px;
  scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
.prv-wz-dates::-webkit-scrollbar{display:none}
.prv-wz-datebtn{
  min-width:64px;padding:12px 6px;background:#fff;color:var(--wz-ink);
  border:1.5px solid var(--wz-line);border-radius:12px;cursor:pointer;
  scroll-snap-align:start;flex-shrink:0;transition:all 150ms;font-family:inherit;position:relative;
}
.prv-wz-datebtn.selected{background:var(--wz-ink);color:#fff;border-color:var(--wz-ink)}
.prv-wz-datebtn-dow{font-size:11px;font-weight:600;opacity:.55;text-transform:uppercase;letter-spacing:.06em}
.prv-wz-datebtn-num{font-size:22px;font-weight:700;margin-top:4px;letter-spacing:-.02em}
.prv-wz-datebtn-mon{font-size:11px;opacity:.55;margin-top:2px;font-weight:500}
.prv-wz-datebtn.selected .prv-wz-datebtn-dow,.prv-wz-datebtn.selected .prv-wz-datebtn-mon{opacity:.7}
.prv-wz-datebtn-busy{position:absolute;top:6px;right:6px;width:6px;height:6px;border-radius:50%;background:var(--wz-warn)}

.prv-wz-slots{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.prv-wz-slotbtn{
  padding:14px 12px;background:#fff;color:var(--wz-ink);
  border:1.5px solid var(--wz-line);border-radius:10px;font-size:14.5px;font-weight:600;
  font-family:inherit;cursor:pointer;transition:all 150ms;
  display:flex;flex-direction:column;align-items:center;gap:4px;line-height:1.2;
}
.prv-wz-slotbtn.selected{background:var(--wz-ink);color:#fff;border-color:var(--wz-ink)}
.prv-wz-slotbtn[disabled]{background:var(--wz-surface);color:var(--wz-border);border-color:#F1F5F9;text-decoration:line-through;cursor:not-allowed}

/* Avond/nacht-sloten */
.prv-wz-slotbtn.is-night{
  background:#FFF8E6;border-color:#F5C97D;color:#7C5400;
}
.prv-wz-slotbtn.is-night.selected{
  background:#7C5400;border-color:#7C5400;color:#fff;
}
.prv-wz-slotbtn.is-night[disabled]{
  background:#FFFAF0;color:#D6BB7B;border-color:#FBE9C2;
}
.prv-wz-slot-tag{
  font-size:10px;font-weight:600;letter-spacing:.02em;text-transform:uppercase;
  opacity:.85;
}
.prv-wz-slot-section{margin-top:14px}
.prv-wz-slot-section-lbl{
  font-size:11.5px;font-weight:600;color:#7C5400;letter-spacing:.06em;
  text-transform:uppercase;margin-bottom:8px;padding-left:2px;
}

.prv-wz-empty{padding:28px 20px;background:var(--wz-surface);border-radius:12px;text-align:center;color:var(--wz-mute);font-size:14px}

/* Extras / terms checkbox */
.prv-wz-check{
  width:24px;height:24px;border-radius:6px;background:#fff;
  border:1.5px solid var(--wz-border);
  display:flex;align-items:center;justify-content:center;color:#fff;
  flex-shrink:0;margin-top:2px;transition:all 150ms;
}
.prv-wz-card.selected .prv-wz-check,.prv-wz-termbox.selected .prv-wz-check-sm{background:var(--wz-ink);border-color:var(--wz-ink)}

.prv-wz-termbox{
  display:flex;gap:12px;align-items:flex-start;padding:14px;
  background:var(--wz-surface);border-radius:12px;cursor:pointer;
}
.prv-wz-check-sm{
  width:22px;height:22px;border-radius:6px;background:#fff;border:1.5px solid var(--wz-border);
  display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;margin-top:1px;transition:all 150ms;
}
.prv-wz-termtxt{font-size:13.5px;color:var(--wz-ink-2);line-height:1.45}
.prv-wz-termtxt a{color:var(--wz-ink);font-weight:600}

/* Footer CTA */
.prv-wz-footer{
  position:sticky;bottom:0;
  background:linear-gradient(to bottom, rgba(255,255,255,.6), #fff 30%);
  padding:16px 18px 20px;border-top:1px solid #F1F5F9;backdrop-filter:blur(8px);
}
.prv-wz-footer-summary{
  margin-bottom:10px;display:flex;align-items:center;justify-content:space-between;font-size:13px;
}
.prv-wz-footer-summary-lbl{color:var(--wz-mute);font-weight:500}
.prv-wz-footer-summary-val{color:var(--wz-ink);font-weight:700;font-size:16px}
.prv-wz-cta{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:16px 24px;font-size:16px;font-weight:600;font-family:inherit;
  border:0;border-radius:14px;width:100%;min-height:54px;letter-spacing:-.01em;
  background:var(--wz-ink);color:#fff;cursor:pointer;
  box-shadow:0 1px 2px rgba(15,23,42,.08), 0 4px 12px rgba(15,23,42,.12);
  transition:all 180ms cubic-bezier(.2,.8,.2,1);
}
.prv-wz-cta[disabled]{background:var(--wz-border);box-shadow:none;cursor:not-allowed}
.prv-wz-cta-outline{background:#fff;color:var(--wz-ink);box-shadow:inset 0 0 0 1px var(--wz-line)}

/* Confirmation */
.prv-wz-done{flex:1;display:flex;flex-direction:column;background:var(--wz-surface)}
.prv-wz-done-hero{padding:40px 24px 28px;background:#fff;text-align:center}
.prv-wz-done-circle{
  width:72px;height:72px;border-radius:50%;background:var(--wz-ok-bg);
  display:flex;align-items:center;justify-content:center;margin:0 auto 16px;
  color:var(--wz-ok);animation:wzPop 500ms cubic-bezier(.2,.8,.2,1);
}
.prv-wz-done-h1{font-size:24px;font-weight:700;margin:0;letter-spacing:-.02em}
.prv-wz-done-sub{font-size:14.5px;color:var(--wz-mute);margin:8px 0 0;line-height:1.5}
.prv-wz-done-badge{
  margin-top:18px;display:inline-flex;align-items:center;gap:8px;
  padding:6px 12px;background:var(--wz-chip);border-radius:999px;
  font-size:12.5px;font-weight:600;color:var(--wz-ink-2);letter-spacing:.02em;
}
.prv-wz-done-badge code{color:var(--wz-ink);font-family:ui-monospace,monospace}
.prv-wz-done-body{padding:20px 18px;flex:1}
.prv-wz-appt{background:var(--wz-ink);color:#fff;border-radius:16px;padding:20px;margin-bottom:14px}
.prv-wz-appt-head{display:flex;align-items:center;gap:10px;margin-bottom:14px;font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;opacity:.8}
.prv-wz-appt-date{font-size:20px;font-weight:700;letter-spacing:-.01em;line-height:1.25}
.prv-wz-appt-slot{font-size:15px;opacity:.85;margin-top:4px}
.prv-wz-appt-sep{height:1px;background:rgba(255,255,255,.12);margin:16px 0}
.prv-wz-appt-addr{display:flex;align-items:flex-start;gap:10px}
.prv-wz-order{background:#fff;border-radius:16px;padding:18px;border:1px solid var(--wz-line)}
.prv-wz-order-row{display:flex;justify-content:space-between;font-size:14.5px;margin-bottom:10px}
.prv-wz-order-total{display:flex;justify-content:space-between;align-items:baseline}
.prv-wz-order-total-val{font-size:22px;font-weight:700;letter-spacing:-.02em}
.prv-wz-done-footer{padding:16px 18px 20px;background:#fff;border-top:1px solid #F1F5F9;display:flex;gap:10px}

.prv-wz-err-banner{
  padding:12px 14px;background:var(--wz-err-bg);border:1.5px solid var(--wz-err-border);
  border-radius:10px;color:#991B1B;font-size:13.5px;font-weight:500;margin-bottom:14px;
}
