/* VRFH Business Suite — Booking CSS v2.0 */
:root{
  --vrfhb-bg:#0b0b1e;
  --vrfhb-panel:#0f0f28;
  --vrfhb-border:rgba(255,255,255,.09);
  --vrfhb-cyan:#21d7e8;
  --vrfhb-purple:#b57fff;
  --vrfhb-pink:#ee4199;
  --vrfhb-green:#2ecc71;
  --vrfhb-muted:rgba(255,255,255,.45);
  --vrfhb-r:14px;
  --vrfhb-transition:.2s cubic-bezier(.4,0,.2,1);
}

/* ── Wrap ─────────────────────────────────────────── */
.vrfhb-wrap{max-width:780px;margin:0 auto;font-family:inherit;color:#fff}

/* ── Progress ─────────────────────────────────────── */
.vrfhb-progress{display:flex;align-items:center;gap:0;margin-bottom:2.5rem;padding:.1rem 0}
.vrfhb-prog-step{display:flex;flex-direction:column;align-items:center;gap:.4rem;flex:0 0 auto}
.vrfhb-prog-num{width:36px;height:36px;border-radius:50%;border:2px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;color:rgba(255,255,255,.4);transition:all var(--vrfhb-transition)}
.vrfhb-prog-label{font-size:.7rem;color:rgba(255,255,255,.35);font-weight:600;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}
.vrfhb-prog-line{flex:1;height:2px;background:rgba(255,255,255,.1);margin:0 .5rem;position:relative;top:-10px}
.vrfhb-prog-step.vrfhb-prog-active .vrfhb-prog-num{border-color:var(--vrfhb-cyan);background:var(--vrfhb-cyan);color:#060610}
.vrfhb-prog-step.vrfhb-prog-active .vrfhb-prog-label{color:var(--vrfhb-cyan)}
.vrfhb-prog-step.vrfhb-prog-done .vrfhb-prog-num{border-color:var(--vrfhb-green);background:var(--vrfhb-green);color:#060610}
.vrfhb-prog-step.vrfhb-prog-done .vrfhb-prog-num::before{content:"\2713";font-size:.9rem}

/* ── Panel ─────────────────────────────────────────── */
.vrfhb-panel{background:var(--vrfhb-panel);border:1px solid var(--vrfhb-border);border-radius:var(--vrfhb-r);padding:2rem;margin-bottom:1rem}
.vrfhb-panel-hdr{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1.75rem;padding-bottom:1.25rem;border-bottom:1px solid var(--vrfhb-border)}
.vrfhb-panel-icon{width:44px;height:44px;border-radius:10px;background:rgba(33,215,232,.12);border:1px solid rgba(33,215,232,.2);display:flex;align-items:center;justify-content:center;color:var(--vrfhb-cyan);flex-shrink:0}
.vrfhb-panel-title{font-family:var(--font-d,'Bebas Neue',Impact,sans-serif);font-size:1.1rem;letter-spacing:.08em;color:#fff;line-height:1.2}
.vrfhb-panel-sub{font-size:.82rem;color:var(--vrfhb-muted);margin-top:.25rem;line-height:1.5}

/* ── Guest cards ─────────────────────────────────── */
.vrfhb-guest-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.25rem}
.vrfhb-guest-card{background:rgba(255,255,255,.04);border:1.5px solid var(--vrfhb-border);border-radius:12px;padding:1.25rem;display:flex;align-items:center;gap:1rem;transition:border-color var(--vrfhb-transition)}
.vrfhb-guest-card:hover{border-color:rgba(33,215,232,.3)}
.vrfhb-guest-icon{width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.vrfhb-guest-icon--adult{background:rgba(33,215,232,.12);color:var(--vrfhb-cyan)}
.vrfhb-guest-icon--kids{background:rgba(181,127,255,.12);color:var(--vrfhb-purple)}
.vrfhb-guest-info{flex:1}
.vrfhb-guest-name{font-weight:700;font-size:.95rem;margin-bottom:.15rem}
.vrfhb-guest-age{font-size:.75rem;color:var(--vrfhb-muted)}

/* ── Counter ─────────────────────────────────────── */
.vrfhb-counter{display:flex;align-items:center;gap:.5rem;flex-shrink:0}
.vrfhb-cnt-btn{width:36px;height:36px;border-radius:9px;border:1.5px solid rgba(255,255,255,.2);background:rgba(255,255,255,.06);color:#fff;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;font-weight:700;transition:all var(--vrfhb-transition);line-height:1}
.vrfhb-cnt-btn:hover{border-color:var(--vrfhb-cyan);color:var(--vrfhb-cyan);background:rgba(33,215,232,.1)}
.vrfhb-cnt-btn--kids:hover{border-color:var(--vrfhb-purple);color:var(--vrfhb-purple);background:rgba(181,127,255,.1)}
.vrfhb-cnt-val{min-width:32px;text-align:center;font-family:var(--font-d,'Bebas Neue',Impact,sans-serif);font-size:1.5rem;color:#fff;line-height:1}
.vrfhb-cnt-val--kids{color:var(--vrfhb-purple)}

/* ── Age note ─────────────────────────────────────── */
.vrfhb-age-note{display:flex;align-items:flex-start;gap:.5rem;background:rgba(33,215,232,.06);border:1px solid rgba(33,215,232,.15);border-radius:9px;padding:.75rem 1rem;font-size:.8rem;color:rgba(255,255,255,.6);margin-bottom:1.25rem;line-height:1.5}

/* ── Adventure tiles ─────────────────────────────── */
.vrfhb-adv-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--vrfhb-cyan);margin-bottom:.75rem;display:flex;align-items:center;gap:.4rem}
.vrfhb-adv-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:.5rem;margin-bottom:1rem}
.vrfhb-adv-tile{background:rgba(255,255,255,.04);border:1.5px solid var(--vrfhb-border);border-radius:10px;padding:.75rem .5rem;cursor:pointer;transition:all var(--vrfhb-transition);text-align:center;display:flex;flex-direction:column;gap:.2rem;align-items:center}
.vrfhb-adv-tile:hover{border-color:rgba(33,215,232,.4);background:rgba(33,215,232,.05);transform:translateY(-1px)}
.vrfhb-adv-tile.selected{border-color:var(--vrfhb-cyan);background:rgba(33,215,232,.12);box-shadow:0 0 0 1px var(--vrfhb-cyan)}
.vrfhb-adv-tile-num{font-family:var(--font-d,'Bebas Neue',Impact,sans-serif);font-size:1.5rem;color:var(--vrfhb-cyan);line-height:1}
.vrfhb-adv-tile.selected .vrfhb-adv-tile-num{color:#fff}
.vrfhb-adv-tile-lbl{font-size:.62rem;color:var(--vrfhb-muted);text-transform:uppercase;letter-spacing:.04em}
.vrfhb-adv-tile-price{font-size:.72rem;font-weight:700;color:#fff;margin-top:.1rem}
.vrfhb-adv-tile-per{font-size:.62rem;color:var(--vrfhb-muted)}

/* ── Price summary ─────────────────────────────────── */
.vrfhb-price-box{background:rgba(33,215,232,.06);border:1px solid rgba(33,215,232,.2);border-radius:10px;padding:1rem 1.25rem;margin:1rem 0}
.vrfhb-price-row{display:flex;justify-content:space-between;font-size:.875rem;color:rgba(255,255,255,.75);margin-bottom:.4rem}
.vrfhb-price-total{display:flex;justify-content:space-between;font-weight:800;font-size:1.05rem;color:#fff;padding-top:.6rem;border-top:1px solid rgba(33,215,232,.2);margin-top:.4rem}

/* ── Calendar ─────────────────────────────────────── */
.vrfhb-cal-wrap{background:rgba(255,255,255,.03);border:1px solid var(--vrfhb-border);border-radius:12px;overflow:hidden;margin-bottom:1.25rem}
.vrfhb-cal-nav{display:flex;align-items:center;justify-content:space-between;padding:.875rem 1.1rem;border-bottom:1px solid var(--vrfhb-border)}
.vrfhb-cal-month{font-family:var(--font-d,'Bebas Neue',Impact,sans-serif);font-size:1rem;letter-spacing:.05em;color:#fff}
.vrfhb-cal-nav-btn{background:rgba(255,255,255,.06);border:1px solid var(--vrfhb-border);border-radius:7px;color:#fff;padding:.3rem .5rem;cursor:pointer;transition:all var(--vrfhb-transition);display:flex;align-items:center}
.vrfhb-cal-nav-btn:hover{background:rgba(33,215,232,.1);border-color:var(--vrfhb-cyan)}
.vrfhb-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);padding:.5rem .75rem .25rem}
.vrfhb-cal-dow{text-align:center;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--vrfhb-muted);padding:.25rem 0}
.vrfhb-cal-cells{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;padding:.25rem .75rem .75rem}
.vrfhb-cal-cell{text-align:center;border-radius:8px;min-height:36px;display:flex;align-items:center;justify-content:center;flex-direction:column;font-size:.82rem;transition:all var(--vrfhb-transition)}
.vrfhb-cal-cell.open{cursor:pointer;color:#fff}
.vrfhb-cal-cell.open:hover{background:rgba(33,215,232,.12);color:var(--vrfhb-cyan)}
.vrfhb-cal-cell.selected{background:var(--vrfhb-cyan)!important;color:#060610!important;font-weight:700}
.vrfhb-cal-cell.today .vrfhb-cal-day::after{content:'';display:block;width:4px;height:4px;background:var(--vrfhb-cyan);border-radius:50%;margin:.15rem auto 0}
.vrfhb-cal-cell.past{color:rgba(255,255,255,.2);cursor:not-allowed}
.vrfhb-cal-cell.blank{visibility:hidden}

/* ── Time slots ─────────────────────────────────── */
.vrfhb-hours-label{font-size:.8rem;color:var(--vrfhb-muted);margin-bottom:.75rem}
.vrfhb-hours-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(72px,1fr));gap:.5rem;margin-bottom:1rem}
.vrfhb-hour-btn{background:rgba(255,255,255,.05);border:1.5px solid var(--vrfhb-border);border-radius:8px;color:#fff;padding:.55rem .5rem;cursor:pointer;font-size:.85rem;font-weight:600;transition:all var(--vrfhb-transition);text-align:center}
.vrfhb-hour-btn:hover:not(.disabled){border-color:var(--vrfhb-cyan);background:rgba(33,215,232,.1);color:var(--vrfhb-cyan)}
.vrfhb-hour-btn.selected{border-color:var(--vrfhb-cyan);background:var(--vrfhb-cyan);color:#060610}
.vrfhb-hour-btn.disabled{opacity:.3;cursor:not-allowed}

/* ── Summary ─────────────────────────────────────── */
.vrfhb-summary{background:rgba(255,255,255,.04);border:1px solid var(--vrfhb-border);border-radius:10px;padding:1rem 1.25rem;margin-bottom:1.5rem}
.vrfhb-summary-row{display:flex;justify-content:space-between;font-size:.875rem;padding:.35rem 0;color:rgba(255,255,255,.7)}
.vrfhb-summary-total{display:flex;justify-content:space-between;font-weight:800;font-size:1.1rem;color:#fff;border-top:1px solid var(--vrfhb-border);margin-top:.35rem;padding-top:.6rem}

/* ── Form fields ─────────────────────────────────── */
.vrfhb-fields-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem}
.vrfhb-field{display:flex;flex-direction:column;gap:.4rem}
.vrfhb-field label{font-size:.78rem;font-weight:700;color:rgba(255,255,255,.65);text-transform:uppercase;letter-spacing:.04em}
.vrfhb-field input,.vrfhb-field select,.vrfhb-field textarea{
  background:rgba(255,255,255,.06);border:1.5px solid rgba(255,255,255,.12);
  border-radius:9px;color:#fff;font-size:.9rem;padding:.65rem .85rem;
  font-family:inherit;transition:border-color var(--vrfhb-transition),box-shadow var(--vrfhb-transition);
}
.vrfhb-field input:focus,.vrfhb-field select:focus,.vrfhb-field textarea:focus{
  border-color:var(--vrfhb-cyan);outline:none;box-shadow:0 0 0 3px rgba(33,215,232,.12);
}
.vrfhb-field input::placeholder,.vrfhb-field textarea::placeholder{color:rgba(255,255,255,.25)}

/* Gift card code row */
.vrfhb-gc-row{display:flex;gap:.5rem}
.vrfhb-gc-apply-btn{background:rgba(33,215,232,.12);border:1px solid rgba(33,215,232,.3);border-radius:8px;color:var(--vrfhb-cyan);font-size:.8rem;font-weight:700;padding:.6rem 1rem;cursor:pointer;transition:all var(--vrfhb-transition);white-space:nowrap}
.vrfhb-gc-apply-btn:hover{background:var(--vrfhb-cyan);color:#060610}
.vrfhb-gc-msg{font-size:.78rem;margin-top:.4rem}
.vrfhb-gc-msg.ok{color:var(--vrfhb-green)}
.vrfhb-gc-msg.err{color:var(--vrfhb-pink)}

/* ── Payment options ─────────────────────────────── */
.vrfhb-pay-section{margin-bottom:1.25rem}
.vrfhb-pay-section-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--vrfhb-muted);margin-bottom:.65rem}
.vrfhb-pay-opts{display:flex;gap:.65rem;flex-wrap:wrap}
.vrfhb-pay-opt{cursor:pointer}
.vrfhb-pay-opt input{display:none}
.vrfhb-pay-face{display:flex;align-items:center;gap:.5rem;background:rgba(255,255,255,.05);border:1.5px solid rgba(255,255,255,.12);border-radius:9px;padding:.65rem 1rem;font-size:.85rem;font-weight:600;color:rgba(255,255,255,.7);cursor:pointer;transition:all var(--vrfhb-transition)}
.vrfhb-pay-opt input:checked + .vrfhb-pay-face{border-color:var(--vrfhb-cyan);background:rgba(33,215,232,.1);color:var(--vrfhb-cyan)}

/* ── Stripe element ─────────────────────────────── */
.vrfhb-pay-widget{margin-bottom:1.25rem}
.vrfhb-stripe-el{background:rgba(255,255,255,.06);border:1.5px solid rgba(255,255,255,.12);border-radius:9px;padding:.85rem .85rem;transition:border-color var(--vrfhb-transition)}
.vrfhb-stripe-el.StripeElement--focus{border-color:var(--vrfhb-cyan)}
.vrfhb-venue-note{display:flex;align-items:flex-start;gap:.5rem;background:rgba(33,215,232,.06);border:1px solid rgba(33,215,232,.15);border-radius:9px;padding:.75rem 1rem;font-size:.82rem;color:rgba(255,255,255,.65);line-height:1.5}

/* ── PDPA ─────────────────────────────────────────── */
.vrfhb-pdpa{display:flex;align-items:flex-start;gap:.65rem;font-size:.8rem;color:rgba(255,255,255,.55);line-height:1.5;cursor:pointer;margin-bottom:1rem}
.vrfhb-pdpa input{flex-shrink:0;margin-top:.15rem;accent-color:var(--vrfhb-cyan)}
.vrfhb-pdpa a{color:var(--vrfhb-cyan)}

/* ── Actions ─────────────────────────────────────── */
.vrfhb-actions{display:flex;gap:.75rem;align-items:center;justify-content:flex-end;margin-top:1.5rem;padding-top:1.25rem;border-top:1px solid var(--vrfhb-border)}
.vrfhb-btn-next{display:inline-flex;align-items:center;gap:.5rem;background:var(--vrfhb-cyan);color:#060610;font-weight:800;font-size:.9rem;padding:.75rem 1.5rem;border-radius:10px;border:none;cursor:pointer;transition:all var(--vrfhb-transition);letter-spacing:.02em}
.vrfhb-btn-next:hover{background:#1ac4d4;transform:translateY(-1px);box-shadow:0 4px 16px rgba(33,215,232,.3)}
.vrfhb-btn-back{display:inline-flex;align-items:center;gap:.35rem;background:transparent;border:1px solid rgba(255,255,255,.2);color:rgba(255,255,255,.6);font-size:.85rem;font-weight:600;padding:.65rem 1.1rem;border-radius:9px;cursor:pointer;transition:all var(--vrfhb-transition)}
.vrfhb-btn-back:hover{border-color:rgba(255,255,255,.4);color:#fff}
.vrfhb-btn-pay{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;background:var(--vrfhb-cyan);color:#060610;font-weight:800;font-size:.95rem;padding:.8rem 2rem;border-radius:10px;border:none;cursor:pointer;transition:all var(--vrfhb-transition);width:100%;margin-top:1rem}
.vrfhb-btn-pay:hover:not(:disabled){background:#1ac4d4;box-shadow:0 4px 16px rgba(33,215,232,.3)}
.vrfhb-btn-pay:disabled{opacity:.6;cursor:not-allowed}

/* ── Error ─────────────────────────────────────────── */
.vrfhb-error{color:#ff6b6b;font-size:.8rem;margin-top:.5rem;display:flex;align-items:center;gap:.35rem}
.vrfhb-error::before{content:"!";display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;background:#ff6b6b;color:#fff;border-radius:50%;font-size:.65rem;font-weight:800;flex-shrink:0}

/* ── Success ─────────────────────────────────────── */
.vrfhb-success-box{text-align:center;padding:2.5rem 1rem}
.vrfhb-success-icon{width:72px;height:72px;border-radius:50%;background:rgba(46,204,113,.15);border:2px solid var(--vrfhb-green);display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;color:var(--vrfhb-green)}
.vrfhb-success-title{font-family:var(--font-d,'Bebas Neue',Impact,sans-serif);font-size:2.5rem;margin:0 0 .5rem;color:#fff}
.vrfhb-success-ref,.vrfhb-success-email{color:rgba(255,255,255,.6);font-size:.9rem;margin:.25rem 0}
.vrfhb-success-ref strong,.vrfhb-success-email strong{color:var(--vrfhb-cyan)}
.vrfhb-success-detail{background:rgba(255,255,255,.04);border-radius:10px;padding:1rem;margin:1.25rem auto;max-width:360px;text-align:left}
.vrfhb-success-detail p{margin:.3rem 0;font-size:.875rem;color:rgba(255,255,255,.7)}

/* ── Partner stats ─────────────────────────────────── */
.vrfhb-pstats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem}
.vrfhb-pstat{background:rgba(33,215,232,.06);border:1px solid rgba(33,215,232,.15);border-radius:10px;padding:1rem;text-align:center}
.vrfhb-pstat-val{font-family:var(--font-d,'Bebas Neue',Impact,sans-serif);font-size:1.8rem;color:var(--vrfhb-cyan)}
.vrfhb-pstat-lbl{font-size:.72rem;color:rgba(255,255,255,.45);text-transform:uppercase;letter-spacing:.05em}
.vrfhb-ref-box{background:rgba(255,255,255,.04);border:1px solid var(--vrfhb-border);border-radius:10px;padding:1rem 1.25rem}
.vrfhb-ref-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--vrfhb-muted);margin-bottom:.4rem}
.vrfhb-ref-url{font-size:.82rem;color:var(--vrfhb-cyan);word-break:break-all}
.vrfhb-table{width:100%;border-collapse:collapse;font-size:.82rem}
.vrfhb-table th{background:rgba(255,255,255,.06);border-bottom:1px solid var(--vrfhb-border);padding:.5rem .75rem;text-align:left;font-size:.73rem;text-transform:uppercase;letter-spacing:.05em;color:rgba(255,255,255,.5)}
.vrfhb-table td{border-bottom:1px solid rgba(255,255,255,.05);padding:.5rem .75rem;color:rgba(255,255,255,.75)}
.vrfhb-badge{font-size:.68rem;font-weight:700;padding:.15rem .5rem;border-radius:4px;text-transform:uppercase}
.vrfhb-badge--confirmed,.vrfhb-badge--paid{background:rgba(46,204,113,.2);color:#2ecc71}
.vrfhb-badge--pending{background:rgba(255,165,0,.15);color:orange}
.vrfhb-badge--cancelled{background:rgba(255,107,107,.15);color:#ff6b6b}

/* ── Gift card modal (from sc_gift_cards) ─────────── */
.vrfhgc-overlay{position:fixed;inset:0;z-index:99999;background:rgba(6,6,16,.92);display:flex;align-items:center;justify-content:center;padding:1rem}
.vrfhgc-modal{background:#0d0f1f;border:1px solid rgba(33,215,232,.2);border-radius:18px;padding:2rem;max-width:520px;width:100%;position:relative;box-shadow:0 24px 80px rgba(0,0,0,.7);max-height:90vh;overflow-y:auto}
.vrfhgc-close{position:absolute;top:1rem;right:1rem;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:8px;color:#fff;width:32px;height:32px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--vrfhb-transition)}
.vrfhgc-close:hover{background:rgba(255,255,255,.15)}
.vrfhgc-modal-top{text-align:center;padding-bottom:1.5rem;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:1.25rem}
.vrfhgc-modal-tier{font-family:var(--font-d,'Bebas Neue',Impact,sans-serif);font-size:1.5rem;letter-spacing:.08em;color:#fff}
.vrfhgc-modal-amount{font-size:2.5rem;font-weight:900;color:var(--vrfhb-cyan);line-height:1;margin:.25rem 0}
.vrfhgc-modal-sub{font-size:.75rem;color:var(--vrfhb-muted)}

/* ── Responsive ─────────────────────────────────────── */
@media(max-width:680px){
  .vrfhb-guest-row{grid-template-columns:1fr}
  .vrfhb-adv-grid{grid-template-columns:repeat(4,1fr)}
  .vrfhb-fields-grid{grid-template-columns:1fr}
  .vrfhb-pay-opts{flex-direction:column}
  .vrfhb-progress{overflow-x:auto}
  .vrfhb-panel{padding:1.25rem}
  .vrfhb-prog-label{display:none}
  .vrfhb-pstats{grid-template-columns:1fr}
}
@media(max-width:400px){.vrfhb-adv-grid{grid-template-columns:repeat(3,1fr)}}

/* ── Comprehensive mobile fixes ─────────────────────── */
@media(max-width:600px){
  .vrfhb-wrap { padding:.85rem !important; border-radius:10px; }
  .vrfhb-panel { padding:1rem; }
  .vrfhb-fields-grid { grid-template-columns:1fr; gap:.75rem; margin-bottom:1rem; }
  .vrfhb-field input, .vrfhb-field select, .vrfhb-field textarea {
    font-size:16px !important; /* iOS: prevent zoom */
    width:100%; box-sizing:border-box;
  }
  .vrfhb-gc-row { gap:.4rem; }
  .vrfhb-gc-apply-btn { padding:.6rem .75rem; font-size:.78rem; white-space:nowrap; flex-shrink:0; }
  .vrfhb-actions { flex-direction:column-reverse; gap:.6rem; }
  .vrfhb-btn-next, .vrfhb-btn-pay { width:100%; justify-content:center; font-size:.88rem; padding:.8rem 1rem; }
  .vrfhb-btn-back { width:100%; justify-content:center; font-size:.82rem; }
  .vrfhb-summary { padding:.85rem 1rem; }
  .vrfhb-summary-row { font-size:.8rem; flex-wrap:wrap; gap:.15rem; }
  .vrfhb-summary-total { font-size:1rem; }
  .vrfhb-guest-row { grid-template-columns:1fr; gap:.75rem; }
  .vrfhb-guest-card { padding:.9rem; }
  .vrfhb-adv-grid { grid-template-columns:repeat(4,1fr); gap:.35rem; }
  .vrfhb-adv-tile { padding:.6rem .3rem; }
  .vrfhb-adv-tile-num { font-size:1.25rem; }
  .vrfhb-adv-tile-lbl, .vrfhb-adv-tile-per { font-size:.56rem; }
  .vrfhb-hours-grid { grid-template-columns:repeat(3,1fr); gap:.35rem; }
  .vrfhb-cal-cells { gap:2px; padding:.2rem .4rem .4rem; }
  .vrfhb-cal-cell { min-height:30px; font-size:.78rem; border-radius:6px; }
  .vrfhb-cal-grid { padding:.4rem .4rem .2rem; }
  .vrfhb-cal-nav { padding:.7rem .85rem; }
  .vrfhb-progress { margin-bottom:1.5rem; }
  .vrfhb-prog-num { width:30px; height:30px; font-size:.72rem; }
  .vrfhb-pay-method-toggle { flex-direction:column; gap:.5rem; }
  .vrfhb-pay-method-btn { width:100%; font-size:.82rem; padding:.7rem .85rem; }
  /* Gift card modal on mobile */
  .vrfhgc-modal { padding:1.25rem; border-radius:14px; }
  .vrfhgc-modal-amount { font-size:2rem; }
}
@media(max-width:380px){
  .vrfhb-adv-grid { grid-template-columns:repeat(3,1fr); }
  .vrfhb-hours-grid { grid-template-columns:repeat(2,1fr); }
}

/* ── Critical mobile overflow fixes ─────────────────── */
@media(max-width:600px){
  .vrfhb-wrap { overflow:hidden; max-width:100%; box-sizing:border-box; }
  /* Guest cards: single column, fully contained */
  .vrfhb-guest-row { display:flex !important; flex-direction:column !important; gap:.75rem !important; }
  .vrfhb-guest-card {
    width:100% !important; box-sizing:border-box !important;
    flex-wrap:nowrap; gap:.65rem !important; padding:.85rem !important;
  }
  .vrfhb-guest-info { flex:1; min-width:0; overflow:hidden; }
  .vrfhb-guest-age { white-space:normal; line-height:1.25; font-size:.75rem; }
  .vrfhb-counter { flex-shrink:0; }
  /* Fields: always single column, never overflow */
  .vrfhb-fields-grid { grid-template-columns:1fr !important; }
  .vrfhb-field { width:100% !important; box-sizing:border-box !important; }
  /* Gift card apply row */
  .vrfhb-gc-row { flex-wrap:nowrap !important; }
  .vrfhb-gc-input { flex:1; min-width:0; }
  .vrfhb-gc-apply-btn { flex-shrink:0; font-size:.76rem !important; padding:.55rem .65rem !important; }
  /* Pay method toggle full-width */
  .vrfhb-pay-method-toggle { flex-direction:column !important; }
  .vrfhb-pay-method-btn { min-width:0 !important; }
  /* Actions: stacked */
  .vrfhb-actions { gap:.5rem; }
}
