*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--accent:#6366f1;--bg:#f5f5f7;--surface:#fff;--text:#111827;--text-muted:#6b7280;--text-light:#9ca3af;--border:#e5e7eb;--radius:16px;--radius-sm:12px;--radius-xs:8px;--shadow:0 2px 8px #00000014;--shadow-md:0 8px 24px #0000001f;--t:.18s ease;--max-w:520px}html,body{color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;font-size:16px;line-height:1.5}#root,.app{flex-direction:column;min-height:100vh;display:flex}.app-footer{border-top:1px solid var(--border);background:var(--surface);justify-content:center;align-items:center;gap:8px;padding:10px 16px;display:flex}.app-footer-link{color:var(--text-light);transition:color var(--t);font-size:11px;text-decoration:none}.app-footer-link:hover{color:var(--text-muted)}.app-footer-brand{color:var(--text-light);font-size:11px}.app-footer-sep{color:var(--border);font-size:11px}.app-header{background:var(--surface);border-bottom:1px solid var(--border);z-index:10;align-items:center;gap:10px;padding:14px 20px;display:flex;position:sticky;top:0}.header-logo{object-fit:contain;border-radius:7px;flex-shrink:0;width:34px;height:34px}.header-business{color:var(--text);letter-spacing:-.02em;font-size:16px;font-weight:600}.app-main{flex:1;justify-content:center;padding:28px 16px 60px;display:flex}.booking-flow{width:100%;max-width:var(--max-w)}.progress{align-items:flex-start;margin-bottom:36px;display:flex}.progress-step{flex-direction:column;flex:1;align-items:center;gap:6px;display:flex;position:relative}.progress-step:not(:last-child):after{content:"";background:var(--border);height:2px;transition:background var(--t);pointer-events:none;position:absolute;top:13px;left:calc(50% + 14px);right:calc(14px - 50%)}.progress-step.done:not(:last-child):after{background:var(--accent)}.progress-dot{border:2px solid var(--border);background:var(--surface);width:28px;height:28px;color:var(--text-muted);transition:all var(--t);z-index:1;border-radius:50%;justify-content:center;align-items:center;font-size:12px;font-weight:600;display:flex;position:relative}.progress-dot svg{stroke:#fff;stroke-width:2.5px;fill:none;width:11px;height:11px}.progress-step.active .progress-dot,.progress-step.done .progress-dot{border-color:var(--accent);background:var(--accent);color:#fff}.progress-label{color:var(--text-light);text-align:center;white-space:nowrap;font-size:11px;font-weight:500}.progress-step.active .progress-label{color:var(--accent);font-weight:600}.step-wrapper{animation:.22s ease-out stepIn}@keyframes stepIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.step-header{margin-bottom:24px}.step-title{color:var(--text);letter-spacing:-.03em;font-size:24px;font-weight:700;line-height:1.2}.step-subtitle{color:var(--text-muted);margin-top:5px;font-size:15px}.btn-back{color:var(--text-muted);cursor:pointer;transition:color var(--t);background:0 0;border:none;align-items:center;gap:4px;margin-bottom:20px;padding:0;font-size:14px;font-weight:500;display:inline-flex}.btn-back:hover{color:var(--text)}.card-grid{gap:10px;display:grid}.card{background:var(--surface);border:2px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;width:100%;transition:border-color var(--t), box-shadow var(--t), transform var(--t);text-align:left;padding:18px 20px;position:relative}.card:hover{border-color:color-mix(in srgb, var(--accent) 50%, var(--border));box-shadow:var(--shadow);transform:translateY(-1px)}.card.selected{border-color:var(--accent);background:color-mix(in srgb, var(--accent) 5%, white);box-shadow:0 0 0 4px color-mix(in srgb, var(--accent) 12%, transparent)}.card-check{background:var(--accent);opacity:0;width:22px;height:22px;transition:opacity var(--t), transform var(--t);border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:14px;right:14px;transform:scale(.7)}.card.selected .card-check{opacity:1;transform:scale(1)}.card-check svg{stroke:#fff;stroke-width:2.5px;fill:none;width:11px;height:11px}.card-name{color:var(--text);margin-bottom:4px;padding-right:30px;font-size:16px;font-weight:600}.card-desc{color:var(--text-muted);margin-bottom:12px;font-size:14px;line-height:1.5}.card-meta{flex-wrap:wrap;gap:8px;display:flex}.meta-pill{color:var(--text-muted);background:var(--bg);border-radius:100px;align-items:center;gap:4px;padding:3px 10px;font-size:13px;font-weight:500;display:inline-flex}.meta-pill svg{stroke:currentColor;fill:none;stroke-width:2px;width:13px;height:13px}.staff-card{align-items:center;gap:14px;display:flex}.staff-avatar{background:color-mix(in srgb, var(--accent) 14%, white);width:44px;height:44px;color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:18px;font-weight:700;display:flex}.staff-name{color:var(--text);font-size:16px;font-weight:600}.btn-continue{background:var(--accent);color:#fff;border-radius:var(--radius-xs);cursor:pointer;width:100%;transition:opacity var(--t), transform var(--t), box-shadow var(--t);border:none;margin-top:24px;padding:15px;font-family:inherit;font-size:16px;font-weight:600}.btn-continue:hover:not(:disabled){opacity:.92;box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-continue:active:not(:disabled){transform:translateY(0)}.btn-continue:disabled{opacity:.4;cursor:not-allowed;box-shadow:none;transform:none}.calendar-container{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:24px;padding:20px}.calendar-nav{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.calendar-month{color:var(--text);font-size:15px;font-weight:600}.btn-nav{border:1px solid var(--border);background:var(--surface);cursor:pointer;width:32px;height:32px;transition:border-color var(--t), color var(--t);color:var(--text-muted);border-radius:8px;justify-content:center;align-items:center;display:flex}.btn-nav:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.btn-nav:disabled{opacity:.3;cursor:default}.btn-nav svg{stroke:currentColor;fill:none;stroke-width:2.5px;width:14px;height:14px}.calendar-grid{grid-template-columns:repeat(7,1fr);gap:2px;display:grid}.calendar-weekday{text-transform:uppercase;letter-spacing:.06em;color:var(--text-light);text-align:center;padding:4px 0 8px;font-size:11px;font-weight:600}.calendar-day{aspect-ratio:1;cursor:pointer;color:var(--text);transition:background var(--t), color var(--t);background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;font-size:14px;font-weight:500;display:flex}.calendar-day:hover:not(:disabled){background:color-mix(in srgb, var(--accent) 10%, transparent);color:var(--accent)}.calendar-day.today{color:var(--accent);font-weight:700}.calendar-day.selected{background:var(--accent);color:#fff;font-weight:600}.calendar-day.selected.today{color:#fff}.calendar-day:disabled{color:var(--border);cursor:default;background:0 0}.calendar-day.empty{cursor:default}.slots-section{margin-top:4px}.slots-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:12px;font-size:12px;font-weight:700}.slots-grid{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}@media (width>=380px){.slots-grid{grid-template-columns:repeat(4,1fr)}}.slot-btn{border:1.5px solid var(--border);border-radius:var(--radius-xs);background:var(--surface);color:var(--text);cursor:pointer;transition:all var(--t);text-align:center;padding:10px 4px;font-family:inherit;font-size:14px;font-weight:500}.slot-btn:hover{border-color:var(--accent);color:var(--accent);background:color-mix(in srgb, var(--accent) 5%, white)}.slot-btn.selected{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}.no-slots{text-align:center;color:var(--text-muted);padding:28px 0;font-size:15px}.form-group{margin-bottom:16px}.form-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:8px;font-size:12px;font-weight:700;display:block}.form-input,.form-textarea{border:1.5px solid var(--border);border-radius:var(--radius-xs);width:100%;color:var(--text);background:var(--surface);transition:border-color var(--t), box-shadow var(--t);-webkit-appearance:none;outline:none;padding:13px 15px;font-family:inherit;font-size:16px}.form-input:focus,.form-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 15%, transparent)}.form-textarea{resize:vertical;min-height:88px;line-height:1.5}.booking-summary{background:var(--bg);border-radius:var(--radius-sm);margin-bottom:24px;padding:18px 20px}.summary-heading{text-transform:uppercase;letter-spacing:.08em;color:var(--text-light);margin-bottom:14px;font-size:11px;font-weight:700}.summary-rows{flex-direction:column;gap:10px;display:flex}.summary-row{justify-content:space-between;align-items:baseline;gap:16px;display:flex}.summary-key{color:var(--text-muted);flex-shrink:0;font-size:14px}.summary-val{color:var(--text);text-align:right;font-size:14px;font-weight:600}.summary-divider{border:none;border-top:1px solid var(--border);margin:2px 0}.summary-price{color:var(--accent);font-size:20px;font-weight:700}.btn-submit{background:var(--accent);color:#fff;border-radius:var(--radius-xs);cursor:pointer;width:100%;transition:opacity var(--t), transform var(--t), box-shadow var(--t);border:none;justify-content:center;align-items:center;gap:8px;padding:15px;font-family:inherit;font-size:16px;font-weight:600;display:flex}.btn-submit:hover:not(:disabled){opacity:.92;box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-submit:disabled{opacity:.55;cursor:not-allowed;transform:none}.success-screen{text-align:center;flex-direction:column;align-items:center;padding:40px 0 24px;animation:.3s ease-out stepIn;display:flex}.success-icon{background:color-mix(in srgb, var(--accent) 13%, white);border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;margin-bottom:22px;display:flex}.success-icon svg{width:34px;height:34px;stroke:var(--accent);stroke-width:2px;fill:none}.success-title{color:var(--text);letter-spacing:-.03em;margin-bottom:8px;font-size:28px;font-weight:800}.success-sub{color:var(--text-muted);max-width:300px;margin-bottom:32px;font-size:15px}.success-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);text-align:left;width:100%;padding:22px 20px}.success-rows{flex-direction:column;gap:14px;display:flex}.success-row{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.success-key{color:var(--text-muted);font-size:14px}.success-val{color:var(--text);text-align:right;font-size:14px;font-weight:600}.success-id{color:var(--text-muted);font-family:SF Mono,Fira Code,monospace;font-size:13px}.pending-badge{color:#92400e;background:#fef3c7;border-radius:100px;align-items:center;gap:6px;padding:5px 12px;font-size:13px;font-weight:600;display:inline-flex}.pending-note{color:var(--text-muted);text-align:left;margin-top:16px;font-size:13px;line-height:1.6}.loading-state{padding:4px 0}.skeleton{background:linear-gradient(90deg, var(--border) 25%, #f0f0f0 50%, var(--border) 75%);background-size:200% 100%;border-radius:8px;animation:1.3s infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.sk-title{width:55%;height:26px;margin-bottom:10px}.sk-sub{width:70%;height:16px;margin-bottom:28px}.sk-card{border-radius:var(--radius-sm);height:90px;margin-bottom:10px}.bs-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);flex-direction:column;gap:20px;padding:28px 24px;display:flex}.bs-badge{letter-spacing:-.01em;border-radius:100px;align-self:flex-start;align-items:center;padding:6px 16px;font-size:14px;font-weight:700;display:inline-flex}.bs-badge--pending{color:#92400e;background:#fef3c7}.bs-badge--confirmed{color:#065f46;background:#d1fae5}.bs-badge--cancelled{color:#6b7280;background:#f3f4f6}.bs-book-again{align-self:flex-start;margin-top:4px;text-decoration:none;display:inline-block}.bs-footer{text-align:center;color:var(--text-light);padding:28px 0 16px;font-size:13px}.bs-not-found{text-align:center;flex-direction:column;align-items:center;gap:8px;padding:64px 24px;display:flex}.bs-not-found-title{color:var(--text);font-size:20px;font-weight:700}.bs-not-found-sub{color:var(--text-muted);font-size:15px}.bs-home-link{color:var(--accent);margin-top:12px;font-size:14px;font-weight:500;text-decoration:none}.bs-home-link:hover{text-decoration:underline}.error-state{text-align:center;flex-direction:column;align-items:center;padding:48px 24px;display:flex}.error-icon{background:#fef2f2;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;margin-bottom:16px;display:flex}.error-icon svg{stroke:#ef4444;stroke-width:2px;fill:none;width:26px;height:26px}.error-title{color:var(--text);margin-bottom:8px;font-size:18px;font-weight:700}.error-msg{color:var(--text-muted);max-width:280px;margin-bottom:24px;font-size:14px;line-height:1.6}.btn-retry{background:var(--text);color:#fff;border-radius:var(--radius-xs);cursor:pointer;transition:opacity var(--t);border:none;padding:11px 24px;font-family:inherit;font-size:15px;font-weight:600}.btn-retry:hover{opacity:.82}.inline-loading{justify-content:center;padding:28px 0;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:26px;height:26px;animation:.65s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.error-banner{border-radius:var(--radius-xs);color:#dc2626;background:#fef2f2;border:1px solid #fecaca;margin-bottom:16px;padding:12px 14px;font-size:14px;line-height:1.5}
