/* S615 Booking — Frontend Form */
.s615bk-form{max-width:600px;margin:0 auto;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif}
.s615bk-steps{display:flex;gap:0;margin-bottom:24px;background:#f5f5f7;border-radius:10px;padding:3px}
.s615bk-step{flex:1;text-align:center;padding:8px 12px;font-size:13px;font-weight:500;color:#aeaeb2;border-radius:7px;transition:all .2s}
.s615bk-step.active{background:#fff;color:#1d1d1f;font-weight:600;box-shadow:0 1px 3px rgba(0,0,0,.08)}
.s615bk-step.done{color:#34c759}
.s615bk-panel{display:none}
.s615bk-panel.active{display:block}
/* Services */
.s615bk-services{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}
.s615bk-service-card{display:flex;align-items:center;gap:12px;padding:16px;border:2px solid #e5e5ea;border-radius:12px;cursor:pointer;transition:all .2s}
.s615bk-service-card:hover{border-color:#d1d4dc;box-shadow:0 2px 8px rgba(0,0,0,.04)}
.s615bk-service-card:has(input:checked){border-color:#2962FF;background:rgba(41,98,255,.03)}
.s615bk-service-card input{display:none}
.s615bk-service-name{font-size:15px;font-weight:600;color:#1d1d1f}
.s615bk-service-desc{font-size:13px;color:#6e6e73;margin-top:2px}
.s615bk-service-meta{display:flex;gap:12px;margin-top:6px;font-size:12px;color:#aeaeb2;font-weight:500}
/* Date & Time */
.s615bk-datetime{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}
.s615bk-datetime label{display:block;font-size:13px;font-weight:600;color:#1d1d1f;margin-bottom:6px}
.s615bk-input{width:100%;padding:10px 14px;border:1px solid #e5e5ea;border-radius:10px;font-size:14px;font-family:inherit;color:#1d1d1f;transition:border .2s}
.s615bk-input:focus{outline:none;border-color:#2962FF;box-shadow:0 0 0 3px rgba(41,98,255,.1)}
.s615bk-slots{display:flex;flex-wrap:wrap;gap:6px}
.s615bk-slot{padding:8px 16px;border:1px solid #e5e5ea;border-radius:8px;font-size:14px;cursor:pointer;transition:all .15s;background:#fff}
.s615bk-slot:hover{border-color:#2962FF;color:#2962FF}
.s615bk-slot.selected{background:#2962FF;color:#fff;border-color:#2962FF}
.s615bk-hint{color:#aeaeb2;font-size:13px;padding:12px 0}
.s615bk-loading{color:#aeaeb2;font-size:13px;padding:12px 0;animation:s615bk-pulse 1.5s ease infinite}
@keyframes s615bk-pulse{0%,100%{opacity:.4}50%{opacity:1}}
/* Fields */
.s615bk-fields{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}
.s615bk-field label{display:block;font-size:13px;font-weight:600;color:#1d1d1f;margin-bottom:4px}
.s615bk-summary{background:#f5f5f7;border-radius:10px;padding:16px;margin-bottom:20px;font-size:14px;line-height:1.6}
.s615bk-summary strong{color:#1d1d1f}
/* Buttons */
.s615bk-btn{padding:12px 28px;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;font-family:inherit}
.s615bk-btn:disabled{opacity:.4;cursor:not-allowed}
.s615bk-next,.s615bk-submit{background:#2962FF;color:#fff}
.s615bk-next:hover:not(:disabled),.s615bk-submit:hover:not(:disabled){background:#1E53E5;transform:translateY(-1px);box-shadow:0 4px 12px rgba(41,98,255,.25)}
.s615bk-back{background:transparent;color:#6e6e73;border:1px solid #e5e5ea}
.s615bk-back:hover{background:#f5f5f7}
.s615bk-nav{display:flex;gap:8px;justify-content:space-between;margin-top:24px}
/* Success */
.s615bk-success{text-align:center;padding:40px 20px}
.s615bk-success .s615bk-icon{font-size:48px;margin-bottom:12px}
.s615bk-success h3{font-size:20px;font-weight:700;color:#1d1d1f;margin:0 0 8px}
.s615bk-success p{font-size:14px;color:#6e6e73;margin:0;line-height:1.5}
/* Services grid */
.s615bk-grid{margin-bottom:24px}
.s615bk-svc-card{background:#fff;border:1px solid #e5e5ea;border-radius:14px;padding:24px;text-align:center;transition:all .2s}
.s615bk-svc-card:hover{border-color:#d1d4dc;box-shadow:0 4px 16px rgba(0,0,0,.06);transform:translateY(-2px)}
.s615bk-svc-name{font-size:17px;font-weight:700;color:#1d1d1f;margin-bottom:6px}
.s615bk-svc-price{font-size:22px;font-weight:700;color:#2962FF;margin-bottom:8px}
.s615bk-svc-desc{font-size:13px;color:#6e6e73;line-height:1.5;margin-bottom:12px}
.s615bk-svc-meta{font-size:12px;color:#aeaeb2;margin-bottom:12px}
.s615bk-svc-btn{display:inline-block;padding:10px 24px;background:#2962FF;color:#fff;border-radius:8px;font-size:14px;font-weight:600;text-decoration:none;transition:all .2s}
.s615bk-svc-btn:hover{background:#1E53E5;transform:translateY(-1px);box-shadow:0 4px 12px rgba(41,98,255,.25);color:#fff}
/* ── Mobile — unified touch-friendly forms ─────── */
@media(max-width:600px){
    /* Container breathing room */
    .s615bk-form{padding:0 16px}

    /* Steps — bigger touch targets */
    .s615bk-steps{font-size:12px;padding:4px}
    .s615bk-step{padding:10px 8px;font-size:12px}

    /* Date/time stack */
    .s615bk-datetime{grid-template-columns:1fr;gap:12px}

    /* Inputs — 16px font prevents iOS zoom, bigger touch target */
    .s615bk-input{font-size:16px;padding:14px 16px;border-radius:12px}

    /* Field labels */
    .s615bk-field label{font-size:14px;margin-bottom:6px}
    .s615bk-datetime label{font-size:14px}

    /* Time slots — bigger for fingers */
    .s615bk-slot{padding:12px 18px;font-size:15px;border-radius:10px}
    .s615bk-slots{gap:8px}

    /* Service cards — roomier */
    .s615bk-service-card{padding:16px 14px;border-radius:14px}
    .s615bk-service-name{font-size:16px}
    .s615bk-service-desc{font-size:14px}

    /* Buttons — full width, tall touch target */
    .s615bk-btn{width:100%;text-align:center;padding:16px 24px;font-size:16px;border-radius:12px}
    .s615bk-nav{flex-direction:column;gap:10px}

    /* Services grid */
    .s615bk-grid{grid-template-columns:1fr !important}
    .s615bk-svc-card{padding:20px 16px}
    .s615bk-svc-btn{width:100%;text-align:center;padding:14px 24px;font-size:15px;border-radius:10px;display:block}

    /* Summary */
    .s615bk-summary{padding:14px;font-size:15px;border-radius:12px}

    /* Success */
    .s615bk-success{padding:32px 16px}
    .s615bk-success h3{font-size:18px}
    .s615bk-success p{font-size:15px}
}
