.bk{--bk-blue:#2e5bfd;--bk-blue-d:#1e40c8;--bk-ink:#1a1a1a;--bk-ink-2:#4b5563;--bk-ink-3:#9ca3af;--bk-line:#e5e7eb;--bk-bg:#f5f6f8;--bk-success:#157f4d;--bk-danger:#c83b2b;max-width:440px;min-height:100vh;color:var(--bk-ink);background:#fff;flex-direction:column;margin:0 auto;font-family:Noto Sans TC,system-ui,sans-serif;display:flex;position:relative}.bk-head{border-bottom:1px solid var(--bk-line);flex-shrink:0;justify-content:space-between;align-items:center;height:48px;padding:0 16px;display:flex}.bk-head .bk-ht{align-items:center;gap:6px;min-width:0;font-size:15px;font-weight:700;display:inline-flex}.bk-head .bk-head-ava{object-fit:cover;border-radius:999px;flex-shrink:0;width:22px;height:22px}.bk-head .bk-ico{color:var(--bk-ink-3);cursor:pointer}.bk-body{background:var(--bk-bg);flex-direction:column;flex:1;gap:18px;padding:18px 16px 24px;display:flex;overflow-y:auto}.bk-steps{align-items:center;gap:6px;display:flex}.bk-step{opacity:.5;align-items:center;gap:6px;display:flex}.bk-step.on,.bk-step.done{opacity:1}.bk-step .d{width:22px;height:22px;color:var(--bk-ink-2);background:#e5e7eb;border-radius:999px;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:flex}.bk-step.on .d{background:var(--bk-blue);color:#fff}.bk-step.done .d{background:var(--bk-success);color:#fff}.bk-step .l{font-size:12px;font-weight:500}.bk-step-conn{background:var(--bk-line);flex:1;height:1px}.bk-h{font-size:18px;font-weight:700}.bk-sub{color:var(--bk-ink-2);margin-top:4px;font-size:13px;line-height:1.6}.bk-field{flex-direction:column;gap:6px;display:flex}.bk-fl{color:var(--bk-ink-2);font-size:13px;font-weight:600}.bk-selwrap{position:relative}.bk-sel{appearance:none;border:1px solid var(--bk-line);width:100%;color:var(--bk-ink);background:#fff;border-radius:10px;padding:11px 36px 11px 12px;font-size:14px}.bk-sel:focus{border-color:var(--bk-blue);box-shadow:0 0 0 1.5px var(--bk-blue);outline:none}.bk-selwrap .bk-caret{pointer-events:none;color:var(--bk-ink-3);position:absolute;top:50%;right:12px;transform:translateY(-50%)}.bk-field.invalid .bk-sel,.bk-field.invalid .bk-input{border-color:var(--bk-danger);box-shadow:0 0 0 1.5px var(--bk-danger)}.bk-err{color:var(--bk-danger);align-items:center;gap:4px;font-size:12px;font-weight:600;display:flex}.bk-input{border:1px solid var(--bk-line);width:100%;color:var(--bk-ink);background:#fff;border-radius:10px;padding:11px 12px;font-family:inherit;font-size:14px}.bk-input:focus{border-color:var(--bk-blue);box-shadow:0 0 0 1.5px var(--bk-blue);outline:none}.bk-month{border:1px solid var(--bk-line);background:#fff;border-radius:12px;padding:12px}.bk-mhead{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.bk-mtitle{font-size:14px;font-weight:700}.bk-mnav{color:var(--bk-ink-2);cursor:pointer;border-radius:6px;padding:4px}.bk-mnav:hover{background:#f3f4f6}.bk-mgrid{grid-template-columns:repeat(7,1fr);gap:4px;display:grid}.bk-wd{text-align:center;color:var(--bk-ink-3);padding:4px 0;font-size:11px}.bk-cell{aspect-ratio:1;cursor:pointer;color:var(--bk-ink);border-radius:8px;justify-content:center;align-items:center;font-size:13px;display:flex}.bk-cell.blank{visibility:hidden}.bk-cell.avail:hover{background:var(--bk-blue);color:#fff}.bk-cell.off{color:var(--bk-ink-3);opacity:.45;cursor:default}.bk-cell.full{color:var(--bk-ink-3);cursor:default;text-decoration:line-through}.bk-cell.sel{background:var(--bk-blue);color:#fff;font-weight:700}.bk-legend{color:var(--bk-ink-2);gap:14px;margin-top:10px;font-size:11px;display:flex}.bk-lg{align-items:center;gap:4px;display:flex}.bk-lg .s{border-radius:3px;width:10px;height:10px}.bk-lg .s.avail{background:#dbe3ff}.bk-lg .s.sel{background:var(--bk-blue)}.bk-lg .s.off{background:#e5e7eb}.bk-cap{color:var(--bk-ink-2);letter-spacing:.04em;font-size:11px;font-weight:600}.bk-slotgrid{grid-template-columns:repeat(4,1fr);gap:8px;display:grid}.bk-slot{text-align:center;border:1px solid var(--bk-line);cursor:pointer;background:#fff;border-radius:8px;padding:9px 0;font-size:13px}.bk-slot:hover{border-color:var(--bk-blue)}.bk-slot.sel{background:var(--bk-blue);color:#fff;border-color:var(--bk-blue);font-weight:700}.bk-slot.gone{color:var(--bk-ink-3);cursor:default;background:#f3f4f6;text-decoration:line-through}.bk-hint{color:var(--bk-ink-3);align-items:center;gap:4px;font-size:11px;display:flex}.bk-note{color:var(--bk-ink-2);background:#f3f4f6;border-radius:8px;align-items:flex-start;gap:8px;padding:8px 10px;font-size:12px;line-height:1.6;display:flex}.bk-note .ico{color:var(--bk-ink-3);flex-shrink:0;margin-top:1px}.bk-card{border:1px solid var(--bk-line);background:#fff;border-radius:12px;padding:4px 14px}.bk-sumrow{border-bottom:1px solid var(--bk-line);justify-content:space-between;padding:10px 0;font-size:14px;display:flex}.bk-sumrow:last-child{border-bottom:none}.bk-sumrow .k{color:var(--bk-ink-3)}.bk-sumrow .v{font-weight:600}.bk-foot{border-top:1px solid var(--bk-line);background:#fff;flex-shrink:0;gap:8px;padding:12px 16px;display:flex}.bk-btn{cursor:pointer;border:none;border-radius:10px;flex:1;justify-content:center;align-items:center;gap:6px;padding:13px;font-family:inherit;font-size:15px;font-weight:700;display:flex}.bk-btn.primary{background:var(--bk-blue);color:#fff}.bk-btn.primary:hover{background:var(--bk-blue-d)}.bk-btn.primary:disabled{cursor:not-allowed;background:#c7d0e8}.bk-btn.ghost{color:var(--bk-ink-2);border:1px solid var(--bk-line);background:#fff;flex:none;padding-left:22px;padding-right:22px}.bk-addfriend{text-align:center;background:var(--bk-bg);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;padding:40px 24px;display:flex}.bk-ava{background:var(--bk-blue);color:#fff;border-radius:999px;justify-content:center;align-items:center;width:64px;height:64px;font-size:26px;font-weight:700;display:flex}.bk-ava-img{object-fit:cover;background:0 0}.bk-success-ring{background:var(--bk-success);color:#fff;border-radius:999px;justify-content:center;align-self:center;align-items:center;width:64px;height:64px;display:flex}.bk-bubble-wrap{align-items:flex-start;gap:8px;display:flex}.bk-bubble-ava{background:var(--bk-success);color:#fff;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;display:flex}.bk-bubble{color:#1a1a1a;background:#ebebeb;border-radius:16px;padding:10px 14px;font-size:13px;line-height:1.7;position:relative}.bk-bubble:before{content:"";border:6px solid #0000;border-left-width:0;border-right:8px solid #ebebeb;width:0;height:0;position:absolute;top:11px;left:-6px}.bk-var{color:#1e40c8;background:#dce5ff;border-radius:3px;padding:0 4px;font-size:12px}.bk-scrim{z-index:50;background:#0006;justify-content:center;align-items:center;padding:24px;display:flex;position:absolute;inset:0}.bk-pop{text-align:center;background:#fff;border-radius:14px;max-width:300px;padding:22px 20px}.bk-pop-cap{letter-spacing:.08em;color:var(--bk-danger);font-size:11px;font-weight:600}.bk-pop-t{margin:6px 0 10px;font-size:17px;font-weight:700}.bk-pop-b{color:var(--bk-ink-2);margin-bottom:16px;font-size:13px;line-height:1.7}.bk-tabs{border-bottom:1px solid var(--bk-line);flex-shrink:0;display:flex}.bk-tab{color:var(--bk-ink-3);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:11px 0;font-size:14px;font-weight:600}.bk-tab.on{color:var(--bk-blue);border-bottom-color:var(--bk-blue)}.bk-myloading{text-align:center;color:var(--bk-ink-3);padding:40px 0;font-size:14px}.bk-empty{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:6px;padding:40px 24px;display:flex}.bk-mylist{flex-direction:column;gap:10px;display:flex}.bk-myitem{border:1px solid var(--bk-line);background:#fff;border-radius:12px;justify-content:space-between;align-items:center;gap:12px;padding:14px 16px;display:flex}.bk-myitem-svc{color:var(--bk-ink);font-size:15px;font-weight:700}.bk-myitem-time{color:var(--bk-ink-2);margin-top:3px;font-size:13px}.bk-myitem-status{color:var(--bk-success);background:#e7f5ee;border-radius:999px;flex-shrink:0;padding:4px 10px;font-size:12px;font-weight:600}*{box-sizing:border-box;margin:0;padding:0}body{color:#e2e8f0;background:#0f172a;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.spinner{border:4px solid #334155;border-top-color:#6366f1;border-radius:50%;width:40px;height:40px;margin:0 auto 1rem;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.booking-container{max-width:480px;min-height:100vh;margin:0 auto;padding:1rem 1rem 2rem}.booking-loading{color:#94a3b8;flex-direction:column;justify-content:center;align-items:center;min-height:60vh;display:flex}.booking-header{align-items:center;gap:.75rem;padding:1rem 0 1.25rem;display:flex}.booking-avatar{object-fit:cover;border:2px solid #6366f1;border-radius:50%;flex-shrink:0;width:48px;height:48px}.booking-title{color:#f1f5f9;font-size:1.25rem;font-weight:700}.booking-subtitle{color:#94a3b8;margin-top:.15rem;font-size:.8rem}.booking-card{background:#1e293b;border-radius:.75rem;margin-bottom:.75rem;padding:1.25rem;overflow:hidden}.section-label{color:#6366f1;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem;font-size:.75rem;font-weight:600}.service-grid{grid-template-columns:1fr 1fr;gap:.5rem;display:grid}.service-option{cursor:pointer;background:#0f172a;border:2px solid #334155;border-radius:.625rem;flex-direction:column;padding:.75rem;transition:border-color .2s,background .2s;display:flex}.service-option input[type=radio]{display:none}.service-option.selected{background:#1e1b4b;border-color:#6366f1}.service-name{color:#f1f5f9;margin-bottom:.2rem;font-size:.85rem;font-weight:600}.service-meta{color:#64748b;font-size:.7rem}.service-option.selected .service-meta{color:#a5b4fc}.booking-tabs{background:#1e293b;border-radius:.75rem;gap:.25rem;margin-bottom:.75rem;padding:.25rem;display:flex}.booking-tab{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:.5rem;flex:1;padding:.55rem;font-size:.85rem;font-weight:500;transition:all .2s;position:relative}.booking-tab.active{color:#a5b4fc;background:#0f172a;font-weight:600}.tab-dot{background:#6366f1;border-radius:50%;width:6px;height:6px;display:inline-block;position:absolute;top:6px;right:10px}.form-field{margin-bottom:.75rem}.form-field:last-child{margin-bottom:0}.form-field label{color:#94a3b8;margin-bottom:.35rem;font-size:.8rem;font-weight:500;display:block}.form-field input[type=text],.form-field input[type=tel],.form-field input[type=date],.form-field textarea{color:#e2e8f0;background:#0f172a;border:1px solid #334155;border-radius:.5rem;width:100%;padding:.6rem .75rem;font-family:inherit;font-size:.85rem;transition:border-color .2s}.form-field input:focus,.form-field textarea:focus{border-color:#6366f1;outline:none}.form-field textarea{resize:vertical;min-height:60px}.form-field input[type=date]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}.time-grid{grid-template-columns:repeat(4,1fr);gap:.4rem;display:grid}.time-slot{color:#cbd5e1;cursor:pointer;background:#0f172a;border:1px solid #334155;border-radius:.5rem;padding:.5rem 0;font-size:.8rem;font-weight:500;transition:all .2s}.time-slot:hover{border-color:#6366f1}.time-slot.selected{color:#fff;background:#6366f1;border-color:#6366f1;font-weight:600}.time-slot.disabled{opacity:.3;cursor:not-allowed;color:#475569;background:#0f172a;border-color:#1e293b}.booking-btn{cursor:pointer;border:none;border-radius:.625rem;width:100%;margin-bottom:.5rem;padding:.75rem;font-size:.9rem;font-weight:600;transition:background .2s,opacity .2s;display:block}.booking-btn.primary{color:#fff;background:#6366f1}.booking-btn.primary:hover{background:#4f46e5}.booking-btn.primary:disabled{color:#64748b;cursor:not-allowed;background:#334155}.booking-btn.secondary{color:#94a3b8;background:0 0;border:1px solid #334155}.booking-btn.full{margin-top:.5rem}.form-field input[type=date]{appearance:none;max-width:100%;min-height:2.5rem}.success-icon{margin-bottom:.75rem;font-size:3rem}.booking-summary{text-align:left;background:#0f172a;border-radius:.625rem;margin-bottom:1.25rem;padding:1rem}.summary-row{border-bottom:1px solid #1e293b;justify-content:space-between;padding:.5rem 0;display:flex}.summary-row:last-child{border-bottom:none}.summary-label{color:#64748b;font-size:.8rem}.summary-value{color:#e2e8f0;font-size:.8rem;font-weight:600}.booking-error{color:#f87171;background:#f871711a;border:1px solid #f87171;border-radius:.5rem;margin-bottom:.75rem;padding:.6rem .75rem;font-size:.8rem}.party-size-row{justify-content:center;align-items:center;gap:1.25rem;display:flex}.stepper-btn{color:#a5b4fc;cursor:pointer;background:0 0;border:2px solid #6366f1;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.25rem;font-weight:700;transition:background .2s,opacity .2s;display:flex}.stepper-btn:hover{background:#1e1b4b}.stepper-btn:disabled{color:#475569;cursor:not-allowed;background:0 0;border-color:#334155}.party-size-value{color:#f1f5f9;text-align:center;min-width:2.5rem;font-size:1.5rem;font-weight:700}.duration-options{gap:.5rem;display:flex}.duration-btn{color:#cbd5e1;cursor:pointer;background:#0f172a;border:2px solid #334155;border-radius:.625rem;flex:1;padding:.6rem 0;font-size:.85rem;font-weight:500;transition:all .2s}.duration-btn:hover{border-color:#6366f1}.duration-btn.selected{color:#a5b4fc;background:#1e1b4b;border-color:#6366f1;font-weight:600}.calendar{-webkit-user-select:none;user-select:none}.calendar-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.calendar-title{color:#e2e8f0;font-size:.9rem;font-weight:600}.calendar-nav{color:#94a3b8;cursor:pointer;background:#0f172a;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:1rem;transition:background .2s;display:flex}.calendar-nav:hover{background:#334155}.calendar-nav:disabled{opacity:.3;cursor:not-allowed}.calendar-weekdays{grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:.4rem;display:grid}.calendar-weekday{text-align:center;color:#64748b;padding:.25rem 0;font-size:.7rem;font-weight:600}.calendar-grid{grid-template-columns:repeat(7,1fr);gap:3px;display:grid}.calendar-day{aspect-ratio:1;color:#cbd5e1;cursor:pointer;background:#0f172a;border:1px solid #0000;border-radius:.5rem;justify-content:center;align-items:center;font-size:.8rem;font-weight:500;transition:all .15s;display:flex}.calendar-day:hover:not(.disabled):not(.selected){background:#1e1b4b;border-color:#6366f1}.calendar-day.today:not(.selected){border-color:#475569}.calendar-day.selected{color:#fff;background:#6366f1;border-color:#6366f1;font-weight:700}.calendar-day.disabled{opacity:.25;cursor:not-allowed;color:#475569;background:0 0;text-decoration:line-through}.calendar-day.closed{opacity:.3;cursor:not-allowed;color:#475569;background:#1e293b}.calendar-day.empty{cursor:default;background:0 0}
