/* ── Original 1.5.109 styles — unchanged ── */
.hsb-widget-wrap { width:100%; }
:root { --hsb-accent: #C8A96D; }
.hsb-widget { font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif; max-width: 100%; width: 100%; margin: 0; color: #1C1C1A; padding: 12px 14px; box-sizing: border-box; }

/* ── Step bar — desktop default (left sidebar) ── */
.hsb-steps { display: flex; align-items: center; margin-bottom: 1.5rem; }
.hsb-steps-hidden { display: none; }
.hsb-steps-left { flex-direction: column; align-items: flex-start; gap: 6px; margin-bottom: 0; margin-right: 1.5rem; min-width: 140px; }
.hsb-steps-left .hsb-step-line { width: 1px; height: 20px; margin: 0 12px; }
.hsb-widget:has(.hsb-steps-left) { display: flex; align-items: flex-start; gap: 0; width: 100%; box-sizing: border-box; }
.hsb-widget:has(.hsb-steps-left) .hsb-steps-left { border-right: 1px solid #e0e0dc; padding-right: 1rem; padding-top: .5rem; }
.hsb-step { display: flex; align-items: center; gap: 6px; }
.hsb-step-num { width: 26px; height: 26px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 11px; font-weight: 600; background: #f0f0ee; color: #999; border: 1.5px solid #ddd; transition: all .2s; }
.hsb-step-label { font-size: 12px; color: #999; }
.hsb-step.active .hsb-step-num { background: var(--hsb-accent); color: #fff; border-color: var(--hsb-accent); }
.hsb-step.active .hsb-step-label { color: #1C1C1A; font-weight: 500; }
.hsb-step.done .hsb-step-num { background: var(--hsb-accent); color: #fff; border-color: var(--hsb-accent); }
.hsb-step.done { cursor: pointer; }
.hsb-step.done:hover .hsb-step-num { opacity: 0.8; }
.hsb-step.done:hover .hsb-step-label { color: var(--hsb-accent); }
.hsb-step-line { flex: 1; height: 1px; background: #e0e0dc; margin: 0 8px; min-width: 16px; }

/* ── Panels ── */
.hsb-panel { display: none; }
.hsb-panel.active { display: flex; flex-direction: column; flex: 1; min-width: 0; width: 100%; box-sizing: border-box; align-items: stretch; }
.hsb-panel-inner { width: 100%; box-sizing: border-box; display: flex; flex-direction: column; gap: 0; }
.hsb-panel-title { font-size: 14px; font-weight: 600; color: #666; text-transform: uppercase; letter-spacing: .06em; margin-bottom: 1rem; }

/* ── Service cards ── */
.hsb-session-option { border: var(--hsb-card-border-width, 1.5px) solid var(--hsb-card-border-color, #e0e0dc); border-radius: var(--hsb-card-border-radius, 12px); padding: var(--hsb-card-padding-v, 22px) var(--hsb-card-padding-h, 24px); margin-bottom: var(--hsb-card-gap, 14px); margin-left: auto; margin-right: auto; max-width: var(--hsb-card-max-width, 100%); width: 100%; box-sizing: border-box; cursor: pointer; transition: all .15s; background: #fff; }
.hsb-session-option:hover { border-color: var(--hsb-accent); box-shadow: 0 2px 12px rgba(0,0,0,.06); }
.hsb-session-option.selected { border-color: var(--hsb-accent); background: #fdf8f0; box-shadow: 0 2px 12px rgba(200,169,109,.15); }
.hsb-so-header { display: flex; align-items: flex-start; gap: 16px; }
.hsb-so-photo { width: 72px; height: 72px; border-radius: 50%; object-fit: cover; flex-shrink: 0; border: 2.5px solid var(--hsb-accent); }
.hsb-so-body { flex: 1; min-width: 0; }
.hsb-so-name { font-size: 16px; font-weight: 700; margin-bottom: 5px; color: #1C1C1A; }
.hsb-so-desc { font-size: 13px; color: #555; line-height: 1.55; margin-bottom: 8px; }
.hsb-so-meta { display: flex; align-items: center; gap: 16px; font-size: 13px; color: #666; flex-wrap: wrap; }
.hsb-so-price { font-weight: 600; color: var(--hsb-accent); }
.hsb-so-deposit { font-size: 12px; color: #999; margin-top: 4px; }

/* ── Time groups ── */
.hsb-time-group { margin-bottom: 1.75rem; }
.hsb-time-group:last-child { margin-bottom: 0; }
.hsb-time-group-label { font-size: 11px; font-weight: 700; color: #999; text-transform: uppercase; letter-spacing: .08em; margin-bottom: 10px; padding-bottom: 6px; border-bottom: 1px solid #f0f0ee; }

/* ── Calendar ── */
.hsb-calendar-wrap { border: 1px solid #e0e0dc; border-radius: 14px; padding: 20px; margin-bottom: 1rem; background: #fff; box-sizing: border-box; }.hsb-cal-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
.hsb-cal-month-label { font-size: 16px; font-weight: 700; color: #1C1C1A; letter-spacing: .01em; }
.hsb-cal-nav { background: none !important; background-color: transparent !important; border: 1.5px solid #e0e0dc !important; border-radius: 8px !important; width: 32px !important; height: 32px !important; cursor: pointer !important; font-size: 14px !important; color: #555 !important; box-shadow: none !important; padding: 0 !important; transition: all .15s !important; line-height: 1 !important; }
.hsb-cal-nav:hover { border-color: var(--hsb-accent) !important; color: var(--hsb-accent) !important; }
.hsb-cal-weekdays { display: grid; grid-template-columns: repeat(7,1fr); gap: 6px; margin-bottom: 8px; }
.hsb-cal-weekdays span { text-align: center; font-size: 11px; font-weight: 600; color: #aaa; padding: 4px 0; letter-spacing: .05em; text-transform: uppercase; }
.hsb-cal-grid-wrap { background: #e8e8e4; border-radius: 10px; padding: 1px; }
.hsb-cal-grid { display: grid; grid-template-columns: repeat(7,1fr); gap: 2px; border-radius: 10px; overflow: hidden; }
.hsb-cal-day { aspect-ratio: 1/1; display: flex; flex-direction: column; align-items: center; justify-content: center; font-size: 14px; font-weight: 500; border: none; border-radius: 0; transition: all .15s; cursor: pointer; position: relative; min-height: 44px; width: 100%; box-sizing: border-box; background: #fff; }
.hsb-cal-day.available { color: #1C1C1A; background: #fff; }
.hsb-cal-day.available:hover { background: #fdf8f0; color: var(--hsb-accent); }
.hsb-cal-day.today { outline: 2px solid var(--hsb-accent) !important; outline-offset: -2px !important; color: var(--hsb-accent) !important; font-weight: 700 !important; background: #fff !important; z-index: 1; }
.hsb-cal-day.today:hover { background: #fdf8f0 !important; }
.hsb-cal-day.selected { background: var(--hsb-accent) !important; color: #fff !important; font-weight: 700 !important; box-shadow: inset 0 0 0 2px rgba(255,255,255,.2) !important; z-index: 1; outline: none !important; }
.hsb-cal-day.unavailable { color: #bbb; cursor: not-allowed; background: #f4f4f2; }
.hsb-cal-day.unavailable:hover { background: #f4f4f2; color: #bbb; }
.hsb-cal-day.unavailable .hsb-cal-day-num { line-height: 1; margin-bottom: 2px; }
.hsb-cal-day.unavailable::after { content: '✕'; font-size: 8px; color: #ccc; line-height: 1; display: block; position: absolute; bottom: 6px; left: 50%; transform: translateX(-50%); pointer-events: none; }

/* ── Date & Time two-column layout ── */
:root { --hsb-cal-col: 1fr; --hsb-time-col: 1fr; --hsb-dt-gap: 24px; }
.hsb-datetime-layout { display: grid; grid-template-columns: var(--hsb-cal-col) var(--hsb-time-col); gap: var(--hsb-dt-gap); align-items: start; margin-bottom: 1rem; width: 100%; box-sizing: border-box; }
.hsb-datetime-layout > * { min-width: 0; overflow: hidden; box-sizing: border-box; width: 100%; }
.hsb-datetime-layout .hsb-calendar-wrap { overflow: visible; margin-bottom: 0; }

/* ── Time slots panel ── */
.hsb-time-slots-panel-title { font-size: 14px; font-weight: 700; color: #1C1C1A; text-transform: uppercase; letter-spacing: .06em; margin-bottom: 1.25rem; padding-bottom: .75rem; border-bottom: 1.5px solid #e8e8e4; }
.hsb-time-slots-wrap { max-height: 480px; overflow-y: auto; overflow-x: hidden; padding: 0; scrollbar-width: none; -ms-overflow-style: none; width: 100%; box-sizing: border-box; }
.hsb-time-slots-wrap::-webkit-scrollbar { width: 0; height: 0; display: none; background: transparent; }
.hsb-time-slots { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-top: .25rem; }
.hsb-time-slot { border: 1.5px solid #e6e6e2; border-radius: 10px; padding: 13px 10px; text-align: center; font-size: 14px; cursor: pointer; transition: all .15s; font-weight: 500; color: #333; background: #fff; min-width: 0; overflow: hidden; }
.hsb-time-slot:hover { border-color: var(--hsb-accent); color: var(--hsb-accent); background: #fdf8f0; }
.hsb-time-slot.selected { background: var(--hsb-accent); color: #fff; border-color: var(--hsb-accent); font-weight: 600; box-shadow: 0 2px 8px rgba(200,169,109,.25); }
.hsb-time-slot.booked { opacity: .35; cursor: default; text-decoration: line-through; }

/* ── Mobile: stack calendar above time slots ── */
@media (max-width: 640px) {
    .hsb-datetime-layout { grid-template-columns: 1fr; }
    .hsb-time-slots-wrap { max-height: 260px; }
    .hsb-time-slots { grid-template-columns: repeat(2, 1fr); }
    .hsb-cal-day { min-height: 36px; font-size: 13px; }
}

/* ── Form fields ── */
.hsb-selected-session-bar { background: #1C1C1A; border-radius: 8px; padding: 12px 16px; font-size: 14px; color: #C8A96D; margin-bottom: 1.25rem; font-weight: 600; border: 1px solid #C8A96D; }
.hsb-form-grid { display: grid; grid-template-columns: 1fr; gap: 16px; align-items: start; width: 100%; box-sizing: border-box; transition: max-width .2s; }
.hsb-fg { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.hsb-fg.full { grid-column: 1 / -1; }
.hsb-fg.hsb-fg-check { gap: 0; }
.hsb-fg label { font-size: 13px; color: #555; font-weight: 600; word-break: break-word; overflow-wrap: break-word; margin-bottom: 2px; }
.hsb-fg input, .hsb-fg textarea { font-size: 15px; padding: 12px 16px; border: 1.5px solid #e0e0dc; border-radius: 10px; width: 100%; box-sizing: border-box; font-family: inherit; }
.hsb-fg input:focus, .hsb-fg textarea:focus { outline: none; border-color: var(--hsb-accent); }
.hsb-fg .hsb-tos-label, .hsb-fg .hsb-check-label { word-break: break-word; overflow-wrap: break-word; max-width: 100%; }

/* ── Summary ── */
.hsb-summary { background: #f8f8f6; border-radius: 12px; padding: 1.5rem 1.75rem; margin-bottom: 1.5rem; border: 1px solid #ebebea; }
.hsb-summary-row { display: flex; justify-content: space-between; align-items: center; font-size: 15px; padding: 10px 0; border-bottom: 1px solid #f0f0ee; }
.hsb-summary-row:last-child { border-bottom: none; }
.hsb-summary-row.total { font-weight: 700; border-top: 2px solid #e0e0dc; border-bottom: none; margin-top: 6px; padding-top: 14px; padding-bottom: 4px; font-size: 17px; }
.hsb-summary-row.total span:last-child { color: var(--hsb-accent); font-size: 20px; }
.hsb-summary-row.muted { font-size: 13px; color: #888; border-bottom: none; padding-top: 4px; padding-bottom: 0; }

/* ── Button row ── */
.hsb-btn-row { display: flex; align-items: center; justify-content: flex-end; gap: 14px; margin-top: 1.5rem; padding: 20px 24px; border: 1.5px solid #e0e0dc; border-radius: 12px; background: #fff; width: 100%; box-sizing: border-box; }
.hsb-w-btn { font-family: inherit !important; font-size: 15px; padding: 14px 20px; border-radius: 10px !important; cursor: pointer !important; font-weight: 500; border: none !important; transition: all .15s; box-shadow: none !important; }
.hsb-w-btn:not(.primary) { background: none !important; background-color: transparent !important; color: #666; }
.hsb-w-btn:not(.primary):hover { color: #333; }
/* Primary — original right-aligned style, shrinks gracefully on mobile */
.hsb-w-btn.primary { background: var(--hsb-accent); background-color: var(--hsb-accent); color: #fff; border: 1.5px solid var(--hsb-accent) !important; flex: 0 1 auto; min-width: 0; padding: 14px 36px; border-radius: 10px; font-weight: 600; font-size: 15px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.hsb-w-btn.primary:hover { opacity: .9; }
.hsb-w-btn:disabled { opacity: .5; cursor: default; }

/* ── Confirmation ── */
.hsb-confirm { text-align: center; padding: 2rem 1rem; }
.hsb-confirm-icon { width: 60px; height: 60px; border-radius: 50%; background: #dcfce7; display: flex; align-items: center; justify-content: center; font-size: 26px; margin: 0 auto 1rem; color: #166534; }
.hsb-confirm-title { font-size: 22px; font-weight: 700; margin-bottom: 8px; }
.hsb-confirm-msg { font-size: 14px; color: #666; margin-bottom: 1.5rem; }

/* ── Thank You ── */
.hsb-thankyou { background: #1a1a18; border-radius: 16px; color: #fff; }
.hsb-ty-head { padding: 2.5rem 2rem 2rem; text-align: center; border-bottom: 1px solid rgba(200,169,109,0.3); }
.hsb-ty-icon { width: 56px; height: 56px; border-radius: 50%; background: rgba(200,169,109,0.15); border: 2px solid #C8A96D; display: flex; align-items: center; justify-content: center; font-size: 22px; color: #C8A96D; margin: 0 auto 1rem; }
.hsb-ty-title { font-size: 22px; font-weight: 700; color: #fff; margin: 0 0 10px; }
.hsb-ty-msg { font-size: 14px; color: #aaa; margin: 0 auto; max-width: 500px; line-height: 1.6; }
.hsb-ty-summary { display: flex; align-items: stretch; padding: 0; border-bottom: 1px solid rgba(200,169,109,0.3); }
.hsb-ty-col { flex: 1; padding: 1.5rem 1rem; text-align: center; }
.hsb-ty-divider { width: 1px; background: rgba(200,169,109,0.3); }
.hsb-ty-label { font-size: 12px; color: #888; text-transform: uppercase; letter-spacing: .5px; margin-bottom: 6px; }
.hsb-ty-val { font-size: 15px; font-weight: 700; color: #fff; }
.hsb-ty-cal { padding: 1.5rem 1.5rem; text-align: center; }
.hsb-ty-cal-title { font-size: 14px; font-weight: 600; color: #C8A96D; margin-bottom: 1rem; }
.hsb-ty-cal-btns { display: flex; gap: 8px; justify-content: center; flex-wrap: wrap; }
.hsb-cal-btn { display: inline-flex; align-items: center; gap: 7px; padding: 9px 16px; border-radius: 8px; border: 1.5px solid rgba(255,255,255,0.15); background: rgba(255,255,255,0.05); color: #fff; text-decoration: none; font-size: 13px; font-weight: 500; transition: all .15s; white-space: nowrap; cursor: pointer; font-family: inherit; outline: none; -webkit-appearance: none; appearance: none; box-shadow: none !important; }
.hsb-cal-btn:hover { border-color: #C8A96D; background: rgba(200,169,109,0.1); color: #C8A96D; }

/* ── Errors ── */
.hsb-error { background: #fee2e2; color: #991b1b; border-radius: 8px; padding: 10px 14px; font-size: 13px; margin-top: 8px; }
.hsb-field-error { border-color: #e53e3e !important; background: #fff8f8 !important; }
.hsb-field-error-msg { color: #e53e3e; font-size: 12px; margin-top: 3px; display: block; }
.hsb-validation-banner { background: #fff2f2; border: 1.5px solid #e53e3e; border-radius: 10px; padding: 12px 16px; margin-bottom: 16px; color: #c53030; font-size: 14px; font-weight: 500; }

/* ── Pay button ── */
#hsb-square-payment-form { margin: 0; }
#hsb-square-payment-form iframe { border-radius: 10px !important; }
#hsb-pay-btn { background: linear-gradient(135deg, #C8A96D 0%, #b8935a 100%) !important; border: none !important; color: #fff !important; font-size: 15px !important; font-weight: 700 !important; letter-spacing: .03em !important; padding: 14px 28px !important; border-radius: 12px !important; box-shadow: 0 4px 16px rgba(200,169,109,0.35) !important; transition: all .2s !important; flex: 0 1 auto !important; min-width: 0 !important; overflow: hidden !important; text-overflow: ellipsis !important; white-space: nowrap !important; }
#hsb-pay-btn:hover { transform: translateY(-1px); box-shadow: 0 6px 20px rgba(200,169,109,0.45) !important; }
#hsb-pay-btn:active { transform: translateY(0); }

/* ── Extras ── */
.hsb-session-tick { position:absolute; top:10px; right:12px; width:22px; height:22px; border-radius:50%; background:var(--hsb-accent); color:#fff; display:flex; align-items:center; justify-content:center; font-size:13px; font-weight:700; }
.hsb-session-option { position:relative; }
.hsb-extras-section { margin: 0 0 14px; padding: 18px 20px; background: #fff; border: 1.5px solid #e0e0dc; border-radius: var(--hsb-card-border-radius, 12px); box-shadow: 0 2px 8px rgba(0,0,0,.04); }
.hsb-extras-title { font-size: 13px; font-weight: 600; color: #444; margin-bottom: 14px; padding-bottom: 10px; border-bottom: 1px solid #f0f0ee; }
.hsb-extra-item { padding: 14px 0; border-bottom: 1px solid #f0f0ee; cursor: pointer; }
.hsb-extra-item:last-child { border-bottom: none; padding-bottom: 0; }
.hsb-extra-check-row { display: flex; align-items: center; gap: 14px; width: 100%; }
.hsb-extra-check-row input[type=checkbox] { width: 20px; height: 20px; flex-shrink: 0; accent-color: var(--hsb-accent); cursor: pointer; margin-top: 2px; }
.hsb-extra-label { display: flex; flex-direction: column; gap: 3px; cursor: pointer; flex: 1; min-width: 0; }
.hsb-extra-title-text { font-size: 14px; font-weight: 600; color: #1c1c1a; }
.hsb-extra-desc-text { font-size: 13px; color: #777; margin-top: 1px; }
.hsb-extra-price-text { font-size: 14px; color: var(--hsb-accent); font-weight: 600; margin-top: 2px; }
.hsb-extra-qty { display: inline-flex !important; align-items: center !important; border: 1.5px solid #d0d0cc !important; border-radius: 10px !important; overflow: hidden !important; background: #fff !important; height: 48px !important; box-shadow: none !important; }
.hsb-extra-qty button { width: 56px !important; height: 48px !important; min-width: 56px !important; border: none !important; background: #f8f8f6 !important; background-color: #f8f8f6 !important; cursor: pointer !important; font-size: 22px !important; font-weight: 300 !important; color: #444 !important; transition: all .15s !important; flex-shrink: 0 !important; line-height: 1 !important; border-radius: 0 !important; padding: 0 !important; box-shadow: none !important; }
.hsb-extra-qty button:hover { background: #efefed !important; background-color: #efefed !important; color: var(--hsb-accent) !important; }
.hsb-extra-qty input { width: 80px !important; height: 48px !important; border: none !important; border-left: 1.5px solid #d0d0cc !important; border-right: 1.5px solid #d0d0cc !important; text-align: center !important; font-size: 17px !important; font-weight: 600 !important; outline: none !important; background: #fff !important; background-color: #fff !important; -moz-appearance: textfield !important; color: #1C1C1A !important; padding: 0 !important; box-shadow: none !important; }
.hsb-extra-qty input::-webkit-inner-spin-button, .hsb-extra-qty input::-webkit-outer-spin-button { -webkit-appearance: none !important; margin: 0 !important; }
.hsb-so-desc.expanded { -webkit-line-clamp: unset; overflow: visible; }
.hsb-desc-toggle { display: block; }
.hsb-sum-extra-row { font-size: 14px; color: #555; }
.hsb-sum-extra-row span:last-child { color: var(--hsb-accent); font-weight: 500; }

/* ── Payment panel ── */
.hsb-panel-payment { max-width: 100% !important; width: 100% !important; }
.hsb-panel-payment .hsb-summary { width: 100%; box-sizing: border-box; }
.hsb-panel-payment .hsb-btn-row { width: 100%; box-sizing: border-box !important; margin-top: 2rem !important; }
.hsb-panel-payment.active ~ * { display: none; }
.hsb-widget:has(.hsb-panel-payment.active) .hsb-steps-left { display: none; }

/* ════════════════════════════════════════════════════
   MOBILE LAYOUT — below 768px only
   Shows ONE step at a time: only the active step is
   visible as a clean sticky bar. Done/future steps
   are hidden. No labels squished, no overflow.
   Desktop is completely untouched.
   ════════════════════════════════════════════════════ */

@media (max-width: 767px) {

    /* Stack widget vertically, kill sidebar layout */
    .hsb-widget,
    .hsb-widget:has(.hsb-steps-left) {
        display: flex !important;
        flex-direction: column !important;
        align-items: stretch !important;
    }

    /* Step bar becomes a slim sticky strip */
    .hsb-steps,
    .hsb-steps-left {
        display: flex !important;
        flex-direction: row !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 0 !important;
        margin: 0 !important;
        padding: 0 !important;
        width: 100% !important;
        min-width: unset !important;
        border-right: none !important;
        border-bottom: 1px solid #e0e0dc !important;
        border-radius: 0 !important;
        position: sticky !important;
        top: 0 !important;
        z-index: 100 !important;
        background: #fff !important;
        overflow: visible !important;
    }

    /* Hide ALL steps by default on mobile */
    .hsb-steps .hsb-step,
    .hsb-steps-left .hsb-step { display: none !important; }

    /* Show ONLY the active step */
    .hsb-steps .hsb-step.active,
    .hsb-steps-left .hsb-step.active {
        display: flex !important;
        flex-direction: row !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 10px !important;
        width: 100% !important;
        padding: 14px 20px !important;
        cursor: default !important;
    }

    /* Active step number circle */
    .hsb-steps .hsb-step.active .hsb-step-num,
    .hsb-steps-left .hsb-step.active .hsb-step-num {
        width: 28px !important;
        height: 28px !important;
        font-size: 13px !important;
        flex-shrink: 0 !important;
    }

    /* Active step label — full size, readable */
    .hsb-steps .hsb-step.active .hsb-step-label,
    .hsb-steps-left .hsb-step.active .hsb-step-label {
        font-size: 14px !important;
        font-weight: 600 !important;
        color: #1C1C1A !important;
        white-space: nowrap !important;
    }

    /* Hide all connector lines */
    .hsb-step-line { display: none !important; }

    /* Zero the widget's own padding on mobile — we control it per-panel instead */
    .hsb-widget {
        padding: 0 !important;
    }

    /* Panel fills full width, no horizontal padding */
    .hsb-panel.active {
        width: 100% !important;
        padding: 16px 0 !important;
    }

    /* Everything inside panels gets side padding EXCEPT the calendar wrap */
    .hsb-panel.active .hsb-panel-title,
    .hsb-panel.active .hsb-selected-session-bar,
    .hsb-panel.active .hsb-session-option,
    .hsb-panel.active .hsb-extras-section,
    .hsb-panel.active .hsb-form-grid,
    .hsb-panel.active .hsb-summary,
    .hsb-panel.active .hsb-btn-row,
    .hsb-panel.active .hsb-time-slots-wrap,
    .hsb-panel.active .hsb-panel-inner {
        padding-left: 14px !important;
        padding-right: 14px !important;
    }

    /* Datetime panel: calendar goes full bleed, time slots get padding */
    .hsb-panel-datetime.active .hsb-time-slots-wrap {
        padding-left: 14px !important;
        padding-right: 14px !important;
    }

    /* Calendar wrap: strip everything — border, radius, padding, margin */
    .hsb-calendar-wrap {
        border: none !important;
        border-radius: 0 !important;
        padding: 12px 0 !important;
        margin: 0 !important;
        box-shadow: none !important;
        width: 100% !important;
    }

    /* Calendar stacks above time slots */
    .hsb-datetime-layout { grid-template-columns: 1fr !important; }
    .hsb-time-slots-wrap { max-height: none !important; }
    .hsb-cal-day { min-height: 36px !important; font-size: 13px !important; }

    /* Button row contained */
    .hsb-btn-row { padding: 14px 16px !important; border-radius: 10px !important; }


    /* Buttons — comfortable, text never cut */
    .hsb-w-btn { font-size: 14px !important; padding: 12px 16px !important; }
    .hsb-w-btn.primary { padding: 12px 20px !important; font-size: 14px !important; }
    #hsb-pay-btn { padding: 12px 16px !important; font-size: 14px !important; }
}

/* ════════════════════════════════════════════════════
   DESKTOP — hidden option support (new in 1.5.110)
   Left and Top already work via original CSS above.
   ════════════════════════════════════════════════════ */

.hsb-steps-hidden { display: none !important; }

/* Order Summary Card — individual row classes */
.hsb-sum-title { font-size:10px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:rgba(200,169,109,0.7); margin-bottom:16px; }
.hsb-sum-row-label { font-size:13px; color:rgba(255,255,255,0.55); }
.hsb-sum-row-value { font-size:13px; color:#F7F4EE; font-weight:500; text-align:right; max-width:60%; }
.hsb-pay-deposit-label { font-size:14px; font-weight:700; color:#C8A96D; }
.hsb-pay-deposit-value { font-size:18px; font-weight:800; color:#C8A96D; }
.hsb-pay-balance-label { font-size:12px; color:rgba(255,255,255,0.4); }
.hsb-pay-balance-value { font-size:12px; color:rgba(255,255,255,0.4); }
