/* 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;
}

/* ════════════════════════════════════════════════════════════════════
   v3.0.0 — RESERVATION-ONLY WIZARD
   New components added April 2026 for the simplified 5-step flow.
   Older v2 classes above retained for backward compatibility.
════════════════════════════════════════════════════════════════════ */

/* ─── STAGE 1: PACKAGE GRID ─── */
.wiz-pkg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.25rem}
.wiz-pkg-card{position:relative;border:2px solid var(--rule);border-radius:var(--r);padding:1.5rem 1rem 1.25rem;cursor:pointer;transition:all 0.2s;background:#fff;text-align:center}
.wiz-pkg-card:hover{border-color:#bbb;transform:translateY(-1px)}
.wiz-pkg-card.selected{border-color:var(--blue);background:var(--blue-lt);box-shadow:0 4px 16px rgba(41,121,255,0.12)}
.wiz-pkg-card.featured::before{content:'Most Popular';position:absolute;top:-10px;left:50%;transform:translateX(-50%);background:var(--blue);color:#fff;font-family:var(--fm);font-size:0.62rem;letter-spacing:0.1em;text-transform:uppercase;padding:3px 10px;border-radius:10px;white-space:nowrap}
.wiz-pkg-badge{font-family:var(--fm);font-size:0.6rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--subtle);margin-bottom:0.4rem}
.wiz-pkg-card.selected .wiz-pkg-badge{color:var(--blue)}
.wiz-pkg-name{font-family:var(--fh);font-size:1.5rem;color:var(--dark);letter-spacing:0.02em;margin-bottom:0.4rem}
.wiz-pkg-price{font-family:var(--fh);font-size:2rem;color:var(--dark);line-height:1;letter-spacing:0.01em;margin-bottom:0.5rem}
.wiz-pkg-card.selected .wiz-pkg-price{color:var(--blue)}
.wiz-pkg-price span{font-family:var(--fb);font-size:0.7rem;color:var(--subtle);font-weight:400;margin-left:0.15rem}
.wiz-pkg-desc{font-size:0.78rem;color:var(--subtle);line-height:1.5}

/* ─── STAGE 1: BESPOKE TILE ─── */
.wiz-bespoke-tile{display:flex;align-items:center;gap:1rem;background:var(--dark);color:#fff;border:2px solid var(--dark);border-radius:var(--r);padding:1.1rem 1.4rem;cursor:pointer;transition:all 0.2s;margin-bottom:0.5rem}
.wiz-bespoke-tile:hover{background:#000;border-color:#000}
.wiz-bespoke-tile.selected{border-color:var(--blue);box-shadow:0 0 0 2px var(--blue)}
.wiz-bespoke-icon{width:38px;height:38px;background:rgba(255,255,255,0.08);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:1rem;color:var(--blue);flex-shrink:0}
.wiz-bespoke-text{flex:1;font-size:0.85rem;line-height:1.5;color:rgba(255,255,255,0.78)}
.wiz-bespoke-text strong{display:block;color:#fff;font-weight:600;font-size:0.95rem;margin-bottom:0.15rem}
.wiz-bespoke-arrow{color:var(--blue);font-size:0.85rem;flex-shrink:0}

/* ─── STAGE 1: DATE INPUTS ─── */
.wiz-date-block{margin-top:0.5rem}
.wiz-date-helper{font-size:0.78rem;color:var(--subtle);line-height:1.55;margin-bottom:0.85rem}
.wiz-date-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:0.85rem}
.wiz-date-input{width:100%;padding:0.75rem 0.85rem;border:1.5px solid var(--rule);border-radius:6px;font-family:var(--fb);font-size:0.92rem;color:var(--dark);background:#fff;cursor:pointer;transition:all 0.15s}
.wiz-date-input:hover{border-color:#bbb}
.wiz-date-input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(41,121,255,0.12)}
.wiz-date-input::-webkit-calendar-picker-indicator{cursor:pointer;opacity:0.55;transition:opacity 0.15s}
.wiz-date-input:hover::-webkit-calendar-picker-indicator{opacity:1}
.wiz-date-summary{font-size:0.85rem;color:var(--blue-d);background:var(--blue-lt);border-radius:6px;padding:0.7rem 0.95rem;display:none;align-items:center;gap:0.5rem}
.wiz-date-summary:not(:empty){display:flex}
.wiz-date-summary i{color:var(--blue)}
.wiz-date-summary strong{font-weight:700}

/* ─── STAGE 2: COLLECTION CARDS ─── */
.wiz-collect-list{display:flex;flex-direction:column;gap:0.85rem}
.wiz-collect-card{display:flex;align-items:center;gap:1rem;border:2px solid var(--rule);border-radius:var(--r);padding:1.1rem 1.25rem;cursor:pointer;transition:all 0.2s;background:#fff}
.wiz-collect-card:hover{border-color:#bbb}
.wiz-collect-card.selected{border-color:var(--blue);background:var(--blue-lt)}
.wiz-collect-icon{width:42px;height:42px;background:var(--bg2);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:1.15rem;color:var(--subtle);flex-shrink:0;transition:all 0.2s}
.wiz-collect-card.selected .wiz-collect-icon{background:var(--blue);color:#fff}
.wiz-collect-text{flex:1}
.wiz-collect-name{font-size:0.95rem;font-weight:600;color:var(--dark)}
.wiz-collect-desc{font-size:0.78rem;color:var(--subtle);margin-top:0.15rem;line-height:1.4}
.wiz-collect-price{font-family:var(--fh);font-size:1.4rem;color:var(--dark);letter-spacing:0.02em;flex-shrink:0}
.wiz-collect-card.selected .wiz-collect-price{color:var(--blue)}

/* ─── STAGE 3: PACKING TOGGLE + BUNDLES ─── */
.wiz-pack-toggle{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem}
.wiz-pack-choice-sub{font-size:0.74rem;color:var(--subtle);margin-top:0.4rem;font-weight:400}
.wiz-pack-choice.selected .wiz-pack-choice-sub{color:rgba(255,255,255,0.78)}
.wiz-pack-choice.selected-no .wiz-pack-choice-sub{color:var(--subtle)}

.wiz-pack-bundles{background:var(--bg2);border:1px solid var(--rule);border-radius:var(--r);padding:1.25rem;margin-bottom:1.25rem}
.wiz-bundle-row{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.wiz-bundle-name{font-size:0.95rem;font-weight:600;color:var(--dark)}
.wiz-bundle-sub{font-size:0.78rem;color:var(--subtle);margin-top:0.15rem}
.wiz-bundle-max{font-size:0.74rem;color:var(--subtle);margin-top:0.85rem;font-style:italic}

.wiz-free-boxes-notice{display:flex;align-items:flex-start;gap:0.75rem;background:#e6f9ef;border:1px solid #b3e8cc;border-radius:6px;padding:0.95rem 1.1rem;font-size:0.85rem;color:#0d5c2e;line-height:1.55}
.wiz-free-boxes-notice i{color:var(--green);flex-shrink:0;margin-top:2px}

/* ─── STAGE 4: FORM FIELDS + REFERRAL ─── */
.fg{display:flex;flex-direction:column;gap:0.35rem}
.fg label{font-size:0.78rem;font-weight:600;color:var(--dark);letter-spacing:0.01em}
.fg input,.fg select,.fg textarea{padding:0.7rem 0.85rem;border:1.5px solid var(--rule);border-radius:6px;font-family:var(--fb);font-size:0.92rem;color:var(--dark);background:#fff;transition:all 0.15s}
.fg input:focus,.fg select:focus,.fg textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(41,121,255,0.12)}

.wiz-secure-notice{display:flex;align-items:flex-start;gap:0.5rem;background:var(--blue-lt);border:1px solid rgba(41,121,255,0.2);border-radius:6px;padding:0.85rem 1rem;font-size:0.82rem;color:var(--blue-d)}
.wiz-secure-notice i{margin-top:2px;flex-shrink:0}

.wiz-referral-block{background:#fff7e6;border:1px solid #ffd591;border-radius:var(--r);padding:1.1rem 1.25rem}
.wiz-referral-toggle{display:flex;align-items:flex-start;gap:0.75rem;cursor:pointer}
.wiz-referral-toggle input[type=checkbox]{margin-top:3px;accent-color:var(--blue);flex-shrink:0;width:16px;height:16px;cursor:pointer}
.wiz-referral-toggle-label{flex:1;font-size:0.88rem;color:var(--dark);line-height:1.5}
.wiz-referral-toggle-label strong{display:block;font-weight:700;margin-bottom:0.2rem}
.wiz-referral-desc{font-size:0.78rem;color:var(--subtle);font-weight:400}
.wiz-referral-fields{margin-top:1rem;padding-top:1rem;border-top:1px dashed #ffd591;display:flex;flex-direction:column;gap:0.85rem}
.wiz-referral-note{font-size:0.74rem;color:var(--subtle);font-style:italic;margin:0}

/* ─── PROGRESS DOT: SKIPPED STATE (BESPOKE PATH) ─── */
.wiz-dot.skipped .wiz-dot-circle{background:var(--bg2);border-color:var(--rule);color:#bbb;opacity:0.5}
.wiz-dot.skipped .wiz-dot-label{color:#bbb;opacity:0.5;text-decoration:line-through}

/* ─── RESPONSIVE: v3 components ─── */
@media(max-width:900px){
  .wiz-pkg-grid{grid-template-columns:1fr;gap:0.75rem}
  .wiz-pkg-card.featured::before{top:-9px}
  .wiz-pack-toggle{grid-template-columns:1fr;gap:0.75rem}
  .wiz-date-row{grid-template-columns:1fr}
}
@media(max-width:560px){
  .wiz-pkg-card{padding:1.25rem 0.85rem 1rem}
  .wiz-pkg-name{font-size:1.3rem}
  .wiz-pkg-price{font-size:1.7rem}
  .wiz-bespoke-tile{padding:1rem;gap:0.75rem}
  .wiz-bespoke-icon{width:34px;height:34px}
  .wiz-collect-card{padding:0.95rem 1rem;gap:0.75rem}
  .wiz-collect-price{font-size:1.2rem}
}
