/* 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}

}


/* ── Time Picker (hour:minute selects) ─────── */
.s615bk-tp{display:flex;align-items:center;gap:2px}
.s615bk-tp select{padding:10px 8px;font-size:14px;font-family:inherit;border:1px solid #d0d7de;border-radius:8px;background:#fff;color:#1d1d1f;text-align:center;appearance:none;-webkit-appearance:none;cursor:pointer;min-width:56px;transition:border-color .2s}
.s615bk-tp select:focus{outline:none;border-color:#2962FF;box-shadow:0 0 0 3px rgba(41,98,255,.1)}
.s615bk-tp select:disabled{opacity:.4;cursor:not-allowed}
.s615bk-tp-sep{font-size:16px;font-weight:700;color:#9ca3af;padding:0 2px}
@media(max-width:600px){
    .s615bk-tp select{font-size:16px;padding:12px 10px;min-width:64px}
}
