:root{
  --sa-primary:#2b82c9;
  --sa-primary-2:#1f6faa;
  --sa-muted:#6b7280;
  --sa-border:#e6e9ef;
  --sa-soft:#f6f8fb;
  --sa-shadow: 0 10px 24px rgba(16,24,40,.08);
  --sa-radius:14px;
  --sa-radius-sm:12px;
  --sa-font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, "Noto Sans", "Helvetica Neue", sans-serif;
}

/* conflict shield */
.sa-wizard, .sa-wizard *{ box-sizing:border-box; }
.sa-wizard button, .sa-wizard input{ font:inherit; letter-spacing:inherit; text-transform:none; }
.sa-wizard button{ -webkit-appearance:none; appearance:none; }
.sa-wizard img{ max-width:100%; height:auto; display:block; }

.sa-wizard{
  max-width:1200px;
  margin:0 auto;
  font-family:var(--sa-font);
  color:#0f172a;
}

/* Steps */
.sa-wizard .sa-steps{
  display:flex;
  gap:8px;
  padding:10px;
  background:var(--sa-soft);
  border:1px solid var(--sa-border);
  border-radius:var(--sa-radius);
  overflow:auto;
}
.sa-wizard .sa-step{
  padding:10px 14px;
  border-radius:999px;
  border:1px solid transparent;
  background:transparent;
  font-weight:900;
  cursor:pointer;
  white-space:nowrap;
}
.sa-wizard .sa-step:disabled{ opacity:.45; cursor:not-allowed; }
.sa-wizard .sa-step.active{
  background:var(--sa-primary);
  color:#fff;
  box-shadow:0 8px 14px rgba(43,130,201,.25);
}

/* Mobile progress */
.sa-wizard .sa-mobile-progress{ display:none; }
@media (max-width:560px){
  .sa-wizard .sa-steps{ display:none; }
  .sa-wizard .sa-mobile-progress{
    display:block;
    margin-top:12px;
    padding:12px 14px;
    border:1px solid var(--sa-border);
    border-radius:var(--sa-radius);
    background:var(--sa-soft);
  }
  .sa-wizard .sa-mp-top{ display:flex; justify-content:space-between; align-items:center; }
  .sa-wizard .sa-mp-bar{ height:8px; background:#e9eef7; border-radius:999px; overflow:hidden; margin-top:10px; }
  .sa-wizard .sa-mp-fill{ height:100%; width:25%; background:var(--sa-primary); transition:width .2s ease; }
}

/* Panels */
.sa-wizard .sa-panel{
  display:none;
  margin-top:10px;
  background:#fff;
  padding:18px;
  border:1px solid var(--sa-border);
  border-radius:var(--sa-radius);
  box-shadow:var(--sa-shadow);
}
.sa-wizard .sa-panel.active{ display:block; }
@media (max-width:560px){ .sa-wizard .sa-panel{ padding:14px; } }

/* Services grid */
.sa-wizard .sa-services-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:18px;
}
@media (max-width:992px){ .sa-wizard .sa-services-grid{ grid-template-columns:repeat(2, 1fr);} }
@media (max-width:560px){ .sa-wizard .sa-services-grid{ grid-template-columns:1fr; gap:12px;} }

.sa-wizard .sa-service-card{
  width:100%;
  display:flex;
  gap:18px;
  align-items:stretch;
  padding:18px;
  border:1px solid var(--sa-border);
  border-radius:var(--sa-radius-sm);
  background:#fff;
  cursor:pointer;
  text-align:left;
  transition:transform .12s ease, box-shadow .12s ease, border-color .12s ease;
  min-height:150px;
}
.sa-wizard .sa-service-card:hover{
  border-color:rgba(43,130,201,.35);
  box-shadow:0 12px 22px rgba(16,24,40,.10);
  transform:translateY(-1px);
}
.sa-wizard .sa-service-card.selected{
  border-color:var(--sa-primary);
  box-shadow:0 0 0 3px rgba(43,130,201,.18) inset, 0 14px 28px rgba(16,24,40,.12);
}
.sa-wizard .sa-card-avatar{
  width:160px; height:120px;
  border-radius:18px;
  object-fit:cover;
  border:1px solid rgba(15,23,42,.10);
  box-shadow:0 12px 24px rgba(16,24,40,.12);
  background:#fff;
}
@media (max-width:560px){ .sa-wizard .sa-card-avatar{ width:130px; height:96px; border-radius:16px; } }
.sa-wizard .sa-card-right{ display:flex; flex-direction:column; gap:4px; min-width:0; }
.sa-wizard .sa-card-title{ font-size:16px; font-weight:900; text-transform:lowercase; }
.sa-wizard .sa-card-desc{ font-size:13px; color:var(--sa-muted); line-height:1.45; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.sa-wizard .sa-card-price{ font-size:13px; font-weight:900; opacity:.92; }

/* Form */
.sa-wizard .sa-form{ max-width:640px; display:grid; gap:12px; }
.sa-wizard .sa-field{ display:grid; gap:6px; }
.sa-wizard .sa-field label{ font-size:12px; font-weight:900; }
.sa-wizard .sa-field input{
  padding:11px 12px;
  border:1px solid var(--sa-border);
  border-radius:12px;
  background:#fff;
  outline:none;
}
.sa-wizard .sa-field input:focus{
  border-color:rgba(43,130,201,.55);
  box-shadow:0 0 0 4px rgba(43,130,201,.12);
}
.sa-wizard .sa-picked{
  padding:10px 12px;
  border:1px solid var(--sa-border);
  border-radius:12px;
  background:var(--sa-soft);
  font-weight:900;
}

/* Buttons */
.sa-wizard .sa-row-actions{ display:flex; gap:10px; flex-wrap:wrap; margin-top:6px; }
.sa-wizard .sa-btn{
  padding:11px 16px;
  border-radius:12px;
  border:1px solid transparent;
  cursor:pointer;
  font-weight:900;
  background:var(--sa-primary);
  color:#fff;
  box-shadow:0 10px 18px rgba(43,130,201,.22);
}
.sa-wizard .sa-btn:hover{ background:var(--sa-primary-2); }
.sa-wizard .sa-btn:disabled{ opacity:.55; cursor:not-allowed; box-shadow:none; }
.sa-wizard .sa-btn.secondary{
  background:#fff;
  color:#111827;
  border-color:var(--sa-border);
  box-shadow:none;
}

/* Calendar */
.sa-wizard .sa-calendar{
  border:1px solid var(--sa-border);
  border-radius:14px;
  background:#fff;
  overflow:hidden;
}
.sa-wizard .sa-cal-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:10px 12px;
  background:var(--sa-soft);
  border-bottom:1px solid var(--sa-border);
}
.sa-wizard .sa-cal-title{ font-weight:900; }
.sa-wizard .sa-cal-nav{
  width:36px; height:36px;
  border-radius:12px;
  border:1px solid var(--sa-border);
  background:#fff;
  cursor:pointer;
  font-weight:900;
}
.sa-wizard .sa-cal-week{
  display:grid;
  grid-template-columns:repeat(7,1fr);
  padding:8px 10px;
  font-size:11px;
  color:var(--sa-muted);
  font-weight:800;
}
.sa-wizard .sa-cal-week div{ text-align:center; }
.sa-wizard .sa-cal-grid{
  display:grid;
  grid-template-columns:repeat(7,1fr);
  gap:6px;
  padding:10px;
}
.sa-wizard .sa-cal-day{
  height:38px;
  border-radius:12px;
  border:1px solid var(--sa-border);
  background:#fff;
  cursor:pointer;
  font-weight:900;
}
.sa-wizard .sa-cal-day.selected{ background:var(--sa-primary); border-color:var(--sa-primary); color:#fff; }
.sa-wizard .sa-cal-day.disabled, .sa-wizard .sa-cal-day:disabled{ opacity:.35; cursor:not-allowed; }
.sa-wizard .sa-cal-day.empty{ border-color:transparent; background:transparent; }

/* Time grid */
.sa-wizard .sa-time-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:10px;
}
@media (max-width:560px){ .sa-wizard .sa-time-grid{ grid-template-columns:repeat(3,1fr);} }
.sa-wizard .sa-time{
  padding:10px;
  border-radius:12px;
  border:1px solid var(--sa-border);
  background:#fff;
  cursor:pointer;
  font-weight:900;
}
.sa-wizard .sa-time.selected{ background:rgba(43,130,201,.10); border-color:rgba(43,130,201,.55); }
.sa-wizard .sa-loading, .sa-wizard .sa-empty{ color:var(--sa-muted); font-weight:800; }

/* Summary */
.sa-wizard .sa-summary{ max-width:680px; display:grid; gap:12px; }
.sa-wizard .sa-summary-title{ font-weight:900; font-size:16px; }
.sa-wizard .sa-summary-item{
  display:flex;
  justify-content:space-between;
  gap:12px;
  padding:12px 14px;
  border:1px solid var(--sa-border);
  border-radius:12px;
  background:var(--sa-soft);
}
.sa-wizard .sa-summary-item span{ color:var(--sa-muted); font-weight:800; }
.sa-wizard .sa-summary-item strong{ font-weight:900; }

/* Messages */
.sa-wizard .sa-msg{
  margin-top:10px;
  font-weight:900;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid var(--sa-border);
  background:#fff;
}
.sa-wizard .sa-msg.ok{ color:#0a7a2a; border-color:rgba(10,122,42,.25); background:rgba(10,122,42,.06); }
.sa-wizard .sa-msg.err{ color:#b00020; border-color:rgba(176,0,32,.25); background:rgba(176,0,32,.06); }

.sa-wizard .sa-card-left{ flex:0 0 auto; }
.sa-wizard .sa-card-right{ flex:1 1 auto; min-width:0; }

@media (max-width:380px){ .sa-wizard .sa-service-card{ flex-direction:column; align-items:flex-start; } .sa-wizard .sa-card-avatar{ width:100%; height:160px; } }


/* Breadcrumbs */
.sa-wizard .sa-crumbs{
  margin-top:10px;
  padding:10px 14px;
  border:1px solid var(--sa-border);
  border-radius:var(--sa-radius);
  background:var(--sa-soft);
  font-size:12px;
  color:var(--sa-muted);
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
}
.sa-wizard .sa-crumb{ font-weight:800; }
.sa-wizard .sa-crumb-sep{ opacity:.65; }

/* Service cards: image on top, text below (screenshot-like) */
.sa-wizard .sa-service-card{
  flex-direction:column !important;
  align-items:stretch !important;
  gap:0 !important;
  padding:0 !important;
  overflow:hidden;
  min-height:0 !important;
  border-radius:18px;
}
.sa-wizard .sa-card-media{
  width:100%;
  aspect-ratio: 16 / 9;
  background:#f3f4f6;
}
.sa-wizard .sa-card-image{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.sa-wizard .sa-card-body{
  padding:14px 14px 16px;
  display:flex;
  flex-direction:column;
  gap:6px;
}
.sa-wizard .sa-card-title{ font-size:15px; font-weight:900; text-transform:lowercase; }
.sa-wizard .sa-card-desc{ font-size:13px; color:var(--sa-muted); line-height:1.45; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.sa-wizard .sa-card-price{ font-size:13px; font-weight:900; }

@media (max-width:560px){
  .sa-wizard .sa-card-media{ aspect-ratio: 16 / 10; }
}


/* ===== Premium UI polish ===== */
:root{
  --sa-shadow-soft: 0 10px 30px rgba(0,0,0,.08);
  --sa-shadow-hover: 0 18px 40px rgba(0,0,0,.14);
  --sa-grad: linear-gradient(135deg,#111827,#1f2937);
}

/* cards */
.sa-wizard .sa-service-card{
  background:#fff;
  box-shadow:var(--sa-shadow-soft);
  border:1px solid rgba(0,0,0,.06);
}
.sa-wizard .sa-service-card:hover{
  transform:translateY(-3px);
  box-shadow:var(--sa-shadow-hover);
}
.sa-wizard .sa-service-card.active{
  outline:3px solid rgba(17,24,39,.12);
}

/* image overlay */
.sa-wizard .sa-card-media{
  position:relative;
}
.sa-wizard .sa-card-media::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(to bottom,rgba(0,0,0,.0),rgba(0,0,0,.35));
}

/* price badge */
.sa-wizard .sa-card-price{
  align-self:flex-start;
  margin-top:6px;
  padding:6px 10px;
  border-radius:999px;
  background:#111827;
  color:#fff;
  font-size:12px;
}

/* breadcrumbs */
.sa-wizard .sa-crumbs{
  backdrop-filter: blur(6px);
  background:rgba(255,255,255,.75);
  box-shadow:var(--sa-shadow-soft);
}

/* calendar */
.sa-wizard .flatpickr-calendar.inline{
  border-radius:16px;
  box-shadow:var(--sa-shadow-soft);
}

/* time slots */
.sa-wizard .sa-time{
  border-radius:10px;
  background:#f8fafc;
  transition:.15s;
}
.sa-wizard .sa-time:hover{
  background:#111827;
  color:#fff;
}

/* inputs */
.sa-wizard input{
  border-radius:12px;
  padding:12px 14px;
}
.sa-wizard input:focus{
  outline:none;
  box-shadow:0 0 0 3px rgba(17,24,39,.15);
}

/* buttons */
.sa-wizard .sa-btn{
  border-radius:14px;
  padding:12px 18px;
  font-weight:800;
}
.sa-wizard .sa-btn.primary{
  background:var(--sa-grad);
  color:#fff;
}
.sa-wizard .sa-btn.primary:hover{
  filter:brightness(1.05);
}

/* mobile polish */
@media(max-width:560px){
  .sa-wizard .sa-service-card{
    border-radius:22px;
  }
}
