/* SSM Booking Wizard — standalone plugin CSS */

/* Font Awesome loaded by plugin enqueue */

/* ═══════════════════════════════════════════════
   BOOKING WIZARD
═══════════════════════════════════════════════ */
.wizard-nav{background:var(--dark);height:60px;display:flex;align-items:center;justify-content:space-between;padding:0 2rem;position:sticky;top:0;z-index:100;box-shadow:0 2px 12px rgba(0,0,0,0.25)}
.wizard-nav-logo{font-family:var(--fh);font-size:1.4rem;color:#fff;letter-spacing:0.04em;text-decoration:none}
.wizard-nav-logo span{color:var(--blue)}
.wizard-nav-back{color:rgba(255,255,255,0.6);font-size:0.82rem;display:flex;align-items:center;gap:0.4rem;text-decoration:none;transition:color 0.2s}
.wizard-nav-back:hover{color:#fff}
.wizard-nav-phone{font-family:var(--fm);font-size:0.78rem;color:rgba(255,255,255,0.6)}
.wizard-nav-phone strong{color:#fff}

/* Progress */
.wiz-progress{background:#fff;border-bottom:1px solid var(--rule);padding:1.25rem 2rem}
.wiz-progress-inner{max-width:900px;margin:0 auto;display:flex;align-items:center}
.wiz-dot{display:flex;flex-direction:column;align-items:center;gap:0.35rem;flex:1;position:relative}
.wiz-dot::before{content:'';position:absolute;top:14px;left:50%;width:100%;height:2px;background:var(--rule);z-index:0;transition:background 0.3s}
.wiz-dot:last-child::before{display:none}
.wiz-dot-circle{width:28px;height:28px;border-radius:50%;background:#fff;border:2px solid var(--rule);display:flex;align-items:center;justify-content:center;font-size:0.7rem;font-weight:700;font-family:var(--fm);color:var(--subtle);z-index:1;transition:all 0.3s}
.wiz-dot.active .wiz-dot-circle{background:var(--blue);border-color:var(--blue);color:#fff}
.wiz-dot.done .wiz-dot-circle{background:var(--green);border-color:var(--green);color:#fff}
.wiz-dot.done::before,.wiz-dot.active::before{background:var(--blue)}
.wiz-dot-label{font-family:var(--fm);font-size:0.6rem;letter-spacing:0.08em;text-transform:uppercase;color:var(--subtle);white-space:nowrap;transition:color 0.3s}
.wiz-dot.active .wiz-dot-label{color:var(--blue)}
.wiz-dot.done .wiz-dot-label{color:var(--green)}

/* Layout */
.wiz-wrap{max-width:1080px;margin:0 auto;padding:2.5rem 2rem;display:grid;grid-template-columns:1fr 320px;gap:2.5rem;align-items:start}
.wiz-main{background:#fff;border-radius:12px;box-shadow:var(--sh);overflow:hidden}
.wiz-step{display:none;padding:2.5rem}
.wiz-step.active{display:block}
.wiz-step-title{font-family:var(--fh);font-size:2rem;color:var(--dark);margin-bottom:0.35rem;letter-spacing:0.01em}
.wiz-step-sub{font-size:0.9rem;color:var(--subtle);margin-bottom:2rem;line-height:1.6}

/* Type toggle */
.wiz-type-toggle{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:2rem}
.wiz-type{border:2px solid var(--rule);border-radius:var(--r);padding:1.5rem;text-align:center;cursor:pointer;transition:all 0.2s}
.wiz-type:hover{border-color:#bbb}
.wiz-type.selected{border-color:var(--blue);background:var(--blue-lt)}
.wiz-type i{font-size:2rem;color:var(--subtle);margin-bottom:0.75rem;display:block;transition:color 0.2s}
.wiz-type.selected i{color:var(--blue)}
.wiz-type-name{font-family:var(--fh);font-size:1.2rem;color:var(--dark);margin-bottom:0.2rem;letter-spacing:0.02em}
.wiz-type-sub{font-size:0.78rem;color:var(--subtle)}

/* Duration */
.wiz-duration{margin-bottom:2rem}
.wiz-duration-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:0.75rem}
.wiz-duration-lhs .wiz-label{font-size:0.88rem;font-weight:600;color:var(--dark);display:block;margin-bottom:0.2rem}
.wiz-duration-lhs .wiz-sublabel{font-size:0.78rem;color:var(--subtle)}
.wiz-dur-badge{background:var(--blue);color:#fff;font-family:var(--fh);font-size:1.3rem;min-width:44px;height:44px;border-radius:var(--r);display:flex;align-items:center;justify-content:center;padding:0 0.5rem;letter-spacing:0.02em}
input[type=range]{width:100%;accent-color:var(--blue);cursor:pointer;margin:0.5rem 0}
.wiz-range-labels{display:flex;justify-content:space-between;font-family:var(--fm);font-size:0.62rem;color:var(--subtle)}

/* Counter rows */
.wiz-counter-list{display:flex;flex-direction:column;gap:0.6rem}
.wiz-counter-row{display:flex;align-items:center;justify-content:space-between;padding:0.9rem 1rem;background:var(--bg2);border-radius:6px;border:1px solid var(--rule)}
.wiz-counter-name{font-size:0.9rem;font-weight:500;color:var(--dark)}
.wiz-counter-sub{font-size:0.74rem;color:var(--subtle)}
.wiz-counter{display:flex;align-items:center}
.wiz-cnt-btn{width:34px;height:34px;border:1.5px solid var(--rule);background:#fff;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;transition:all 0.15s;color:var(--mid);font-weight:700}
.wiz-cnt-btn:first-child{border-radius:6px 0 0 6px}
.wiz-cnt-btn:last-child{border-radius:0 6px 6px 0}
.wiz-cnt-btn:hover{background:var(--blue);border-color:var(--blue);color:#fff}
.wiz-cnt-val{width:38px;height:34px;border-top:1.5px solid var(--rule);border-bottom:1.5px solid var(--rule);border-left:none;border-right:none;display:flex;align-items:center;justify-content:center;font-family:var(--fm);font-size:0.88rem;font-weight:700;background:#fff}

/* Size cards */
.wiz-size-cards{display:flex;flex-direction:column;gap:0.85rem}
.wiz-size-card{border:2px solid var(--rule);border-radius:var(--r);padding:1.1rem 1.25rem;cursor:pointer;transition:all 0.2s;display:flex;align-items:center;gap:1.25rem}
.wiz-size-card:hover{border-color:#bbb}
.wiz-size-card.selected{border-color:var(--blue);background:var(--blue-lt)}
.wiz-size-icon{width:42px;height:42px;background:var(--bg2);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:var(--subtle);flex-shrink:0;transition:all 0.2s}
.wiz-size-card.selected .wiz-size-icon{background:var(--blue);color:#fff}
.wiz-size-name{font-family:var(--fh);font-size:1.1rem;color:var(--dark);letter-spacing:0.02em}
.wiz-size-desc{font-size:0.78rem;color:var(--subtle);margin-top:0.1rem}
.wiz-size-price{font-family:var(--fh);font-size:1.5rem;color:var(--dark);text-align:right;flex-shrink:0;line-height:1}
.wiz-size-price span{display:block;font-family:var(--fb);font-size:0.7rem;color:var(--subtle);font-weight:400}

/* Calendar */
.wiz-cal-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}
.wiz-cal-month{font-family:var(--fh);font-size:1.5rem;color:var(--dark);letter-spacing:0.02em}
.wiz-cal-btn{width:36px;height:36px;border:1.5px solid var(--rule);background:#fff;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.15s;color:var(--mid)}
.wiz-cal-btn:hover{background:var(--blue);border-color:var(--blue);color:#fff}
.wiz-day-headers{display:grid;grid-template-columns:repeat(7,1fr);gap:0.5rem;margin-bottom:0.5rem}
.wiz-day-headers span{text-align:center;font-family:var(--fm);font-size:0.6rem;letter-spacing:0.08em;text-transform:uppercase;color:var(--subtle)}
.wiz-date-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:0.5rem;margin-bottom:1.75rem}
.wiz-date-cell{aspect-ratio:1;border:1.5px solid var(--rule);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:0.85rem;cursor:pointer;transition:all 0.15s;font-weight:500}
.wiz-date-cell:hover{border-color:var(--blue);background:var(--blue-lt);color:var(--blue)}
.wiz-date-cell.selected{background:var(--blue);border-color:var(--blue);color:#fff}
.wiz-date-cell.disabled{opacity:0.3;cursor:default;pointer-events:none}
.wiz-date-cell.empty{border:none;cursor:default;pointer-events:none}
.wiz-time-slots{display:grid;grid-template-columns:repeat(3,1fr);gap:0.75rem}
.wiz-time-slot{border:1.5px solid var(--rule);border-radius:6px;padding:0.75rem;text-align:center;cursor:pointer;transition:all 0.15s}
.wiz-time-slot:hover{border-color:var(--blue);background:var(--blue-lt)}
.wiz-time-slot.selected{background:var(--blue);border-color:var(--blue);color:#fff}
.wiz-time-name{font-family:var(--fh);font-size:1.1rem;letter-spacing:0.02em}
.wiz-time-label{font-size:0.72rem;opacity:0.7;margin-top:0.1rem}

/* Confirm */
.wiz-confirm-section{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--rule)}
.wiz-confirm-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.wiz-confirm-label{font-family:var(--fm);font-size:0.62rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--subtle);margin-bottom:0.75rem;display:flex;align-items:center;justify-content:space-between}
.wiz-confirm-label a{color:var(--blue);cursor:pointer;font-size:0.62rem;text-decoration:none}
.wiz-confirm-row{display:flex;justify-content:space-between;font-size:0.9rem;margin-bottom:0.35rem}
.wiz-confirm-check{display:flex;align-items:flex-start;gap:0.65rem;font-size:0.83rem;color:var(--mid);margin-bottom:0.5rem}
.wiz-confirm-check i{color:var(--green);margin-top:2px;flex-shrink:0}

/* Footer buttons */
.wiz-footer{padding:1.75rem 2.5rem;border-top:1px solid var(--rule);display:flex;align-items:center;justify-content:space-between;gap:1rem;background:#fff}
.wiz-btn-back{color:var(--subtle);font-size:0.88rem;font-weight:500;cursor:pointer;background:none;border:none;display:flex;align-items:center;gap:0.4rem;transition:color 0.2s;padding:0}
.wiz-btn-back:hover{color:var(--dark)}
.wiz-btn-continue{background:var(--blue);color:#fff;font-weight:700;font-size:1rem;padding:0.9rem 2.5rem;border:none;border-radius:6px;cursor:pointer;transition:background 0.15s;display:flex;align-items:center;gap:0.5rem}
.wiz-btn-continue:hover{background:var(--blue-d)}
.wiz-btn-submit{background:var(--green);color:#fff;font-weight:700;font-size:1rem;padding:0.9rem 2.5rem;border:none;border-radius:6px;cursor:pointer;transition:background 0.15s;display:flex;align-items:center;gap:0.5rem}
.wiz-btn-submit:hover{background:#159a52}

/* Success */
.wiz-success{display:none;padding:3.5rem 2.5rem;text-align:center}
.wiz-success.active{display:block}
.wiz-success-icon{width:80px;height:80px;background:#e6f9ef;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem;color:var(--green);margin:0 auto 1.5rem}
.wiz-success-title{font-family:var(--fh);font-size:2.5rem;color:var(--dark);margin-bottom:0.75rem}
.wiz-success-sub{font-size:1rem;color:var(--subtle);max-width:38ch;margin:0 auto 2rem;line-height:1.7}

/* Sidebar */
.wiz-sidebar{position:sticky;top:calc(60px + 1.5rem);display:flex;flex-direction:column;gap:1rem}
.wiz-summary{background:#fff;border-radius:12px;box-shadow:var(--sh);padding:1.5rem;border-top:3px solid var(--blue)}
.wiz-summary-title{font-family:var(--fh);font-size:1.4rem;color:var(--dark);margin-bottom:1.25rem;letter-spacing:0.02em}
.wiz-sum-row{display:flex;justify-content:space-between;padding:0.6rem 0;border-bottom:1px solid var(--rule);font-size:0.88rem}
.wiz-sum-row:last-child{border-bottom:none}
.wiz-sum-lbl{color:var(--subtle)}
.wiz-sum-val{font-weight:600;color:var(--dark)}
.wiz-sum-total{display:flex;justify-content:space-between;align-items:baseline;padding:0.85rem 0 0;margin-top:0.5rem;border-top:2px solid var(--dark)}
.wiz-sum-total-lbl{font-family:var(--fh);font-size:1.2rem;letter-spacing:0.02em}
.wiz-sum-total-val{font-family:var(--fh);font-size:1.6rem;color:var(--blue);letter-spacing:0.02em}
.wiz-sum-note{font-size:0.72rem;color:var(--subtle);margin-top:0.5rem;line-height:1.5}
.wiz-trust{background:#fff;border-radius:12px;box-shadow:var(--sh);padding:1.25rem}
.wiz-trust-row{display:flex;align-items:center;gap:0.65rem;padding:0.5rem 0;font-size:0.84rem;color:var(--mid)}
.wiz-trust-row i{color:var(--green);width:16px;text-align:center;flex-shrink:0}

/* Responsive */
@media(max-width:900px){
  .wiz-wrap{grid-template-columns:1fr}
  .wiz-sidebar{position:static}
  .wiz-time-slots{grid-template-columns:repeat(2,1fr)}
  .wiz-type-toggle{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  .wiz-step,.wiz-footer{padding:1.5rem}
  .wiz-type-toggle{grid-template-columns:1fr}
  .wizard-nav-phone{display:none}
}

/* ─── COLLECTION OPTION CARDS ─── */
.wiz-collection-card{border:2px solid var(--rule);border-radius:var(--r);padding:1.1rem 1.25rem;cursor:pointer;transition:all 0.2s;margin-bottom:0}
.wiz-collection-card:hover{border-color:#bbb}
.wiz-collection-card.selected{border-color:var(--blue);background:var(--blue-lt)}
.wcc-top{display:flex;align-items:center;gap:1rem}
.wcc-icon{width:40px;height:40px;background:var(--bg2);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:var(--subtle);flex-shrink:0;transition:all 0.2s}
.wiz-collection-card.selected .wcc-icon{background:var(--blue);color:#fff}
.wcc-name{font-weight:600;font-size:0.92rem;color:var(--dark)}
.wcc-desc{font-size:0.78rem;color:var(--subtle);margin-top:0.1rem}
.wcc-price{font-family:var(--fh);font-size:1.4rem;color:var(--dark);margin-left:auto;flex-shrink:0;letter-spacing:0.02em}
.wiz-collection-card.selected .wcc-price{color:var(--blue)}
.wcc-badge{margin-top:0.65rem;padding:0.35rem 0.75rem;background:#e6f9ef;border-radius:4px;font-size:0.78rem;color:#0d5c2e;display:flex;align-items:center;gap:0.4rem}
.wcc-badge i{color:var(--green);font-size:0.7rem}

/* ─── PACKING STEP YES/NO TOGGLE ─── */
.wiz-pack-toggle { margin-bottom: 1.75rem; }
.wiz-pack-choice { border: 2px solid var(--rule); border-radius: var(--r); padding: 2rem 1rem; text-align: center; cursor: pointer; transition: all 0.2s; }
.wiz-pack-choice:hover { border-color: #bbb; }
.wiz-pack-choice i { font-size: 2rem; color: var(--subtle); display: block; margin-bottom: 0.75rem; transition: color 0.2s; }
.wiz-pack-choice-label { font-family: var(--fh); font-size: 1.2rem; color: var(--dark); letter-spacing: 0.02em; }
.wiz-pack-choice.selected { border-color: var(--blue); background: var(--blue); }
.wiz-pack-choice.selected i { color: #fff; }
.wiz-pack-choice.selected .wiz-pack-choice-label { color: #fff; }
.wiz-pack-choice.selected-no { border-color: var(--rule); background: var(--bg2); }
.wiz-pack-choice.selected-no i { color: var(--subtle); }

/* ─── CALENDAR UNAVAILABLE DATES ─── */
.wiz-date-cell.weekend {
    opacity: 0.25;
    cursor: not-allowed;
    background: var(--bg2);
}
.wiz-date-cell.blocked {
    opacity: 0.4;
    cursor: not-allowed;
    background: #fff0f0;
    color: #c00;
    text-decoration: line-through;
}
