*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#fff;--surface:#f8f9fa;--surface-alt:#f0f1f3;--accent:#111;--accent-soft:#374151;--text:#111;--text-secondary:#6b7280;--text-tertiary:#9ca3af;--success:#059669;--border:#e5e7eb;--radius:10px}html{-webkit-font-smoothing:antialiased;font-size:16px}body{background:var(--bg);color:var(--text);min-height:100dvh;font-family:Inter,system-ui,sans-serif}#root{flex-direction:column;align-items:center;min-height:100dvh;padding:0 16px;display:flex}.booking-shell{width:100%;max-width:520px;padding:32px 0 48px}.wordmark{letter-spacing:.18em;color:#111;text-align:center;text-transform:uppercase;margin-bottom:8px;font-family:Space Grotesk,sans-serif;font-size:2rem;font-weight:700}.location-header{text-align:center;margin-bottom:28px}.location-name{color:var(--text);margin-bottom:4px;font-size:1.1rem;font-weight:600}.location-address{color:var(--text-secondary);font-size:.85rem}.step-indicator{justify-content:center;gap:8px;margin-bottom:32px;display:flex}.step-dot{background:var(--border);border-radius:50%;width:8px;height:8px;transition:background .3s,transform .3s}.step-dot.active{background:var(--accent);transform:scale(1.25)}.step-dot.done{background:var(--accent);opacity:.4}.step-content{animation:.35s both stepIn}@keyframes stepIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.section-title{color:var(--text);margin-bottom:16px;font-size:1.05rem;font-weight:600}.section-subtitle{color:var(--text-secondary);margin-bottom:16px;font-size:.85rem}.barber-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;margin-bottom:24px;display:grid}.barber-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;flex-direction:column;align-items:center;gap:10px;padding:16px 12px;transition:border-color .2s,background .2s,box-shadow .2s;display:flex}.barber-card:hover{border-color:var(--accent);box-shadow:0 1px 4px #0000000f}.barber-card.selected{border-color:var(--accent);background:var(--surface-alt);box-shadow:0 0 0 1px var(--accent)}.barber-avatar{background:var(--surface-alt);width:56px;height:56px;color:var(--accent-soft);border-radius:50%;justify-content:center;align-items:center;font-size:1.25rem;font-weight:600;display:flex;overflow:hidden}.barber-avatar img{object-fit:cover;width:100%;height:100%}.barber-name{text-align:center;font-size:.85rem;font-weight:500}.service-list{flex-direction:column;gap:10px;margin-bottom:24px;display:flex}.service-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;text-align:left;grid-template-columns:1fr auto;align-items:center;gap:16px;padding:14px 16px;transition:border-color .2s,background .2s,box-shadow .2s;display:grid}.service-card:hover{border-color:var(--accent);box-shadow:0 1px 4px #0000000f}.service-card.selected{border-color:var(--accent);background:var(--surface-alt);box-shadow:0 0 0 1px var(--accent)}.service-info{flex-direction:row;align-items:baseline;gap:8px;min-width:0;display:flex}.service-name{font-size:.95rem;font-weight:500;line-height:1.3}.service-duration{color:var(--text-secondary);white-space:nowrap;flex-shrink:0;font-size:.8rem;line-height:1.3}.service-price{color:var(--text);white-space:nowrap;font-size:.95rem;font-weight:600}.date-picker{scrollbar-width:none;gap:8px;margin-bottom:24px;padding-bottom:8px;display:flex;overflow-x:auto}.date-picker::-webkit-scrollbar{display:none}.date-pill{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;flex-direction:column;flex-shrink:0;align-items:center;gap:2px;min-width:60px;padding:10px 14px;transition:border-color .2s,background .2s;display:flex}.date-pill:hover{border-color:var(--accent)}.date-pill.selected{border-color:var(--accent);background:var(--accent);color:#fff}.date-pill .day-name{text-transform:uppercase;color:var(--text-secondary);font-size:.7rem;font-weight:600}.date-pill .day-num{font-size:1rem;font-weight:600}.date-pill.selected .day-name,.date-pill.selected .day-num{color:#fff}.slot-grid{flex-wrap:wrap;gap:8px;margin-bottom:24px;display:flex}.slot-pill{background:var(--surface);border:1px solid var(--border);cursor:pointer;text-align:center;border-radius:20px;padding:8px 16px;font-size:.85rem;font-weight:500;transition:border-color .2s,background .2s,color .2s}.slot-pill:hover{border-color:var(--accent)}.slot-pill.selected{background:var(--accent);border-color:var(--accent);color:#fff}.slot-barber{color:var(--text-secondary);margin-top:2px;font-size:.7rem;display:block}.slot-pill.selected .slot-barber{color:#fff;opacity:.7}.loading{text-align:center;color:var(--text-secondary);padding:32px 0;font-size:.9rem}.empty-state{text-align:center;color:var(--text-tertiary);padding:24px 0;font-size:.9rem}.summary-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:24px;padding:20px}.summary-row{justify-content:space-between;padding:8px 0;display:flex}.summary-row:not(:last-child){border-bottom:1px solid var(--border)}.summary-label{color:var(--text-secondary);font-size:.85rem}.summary-value{font-size:.9rem;font-weight:500}.form-group{margin-bottom:16px}.form-label{color:var(--text-secondary);margin-bottom:6px;font-size:.85rem;display:block}.form-input{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);outline:none;padding:12px 14px;font-family:inherit;font-size:.95rem;transition:border-color .2s}.form-input:focus{border-color:var(--accent)}.form-input::placeholder{color:var(--text-tertiary)}.btn-primary{background:var(--accent);border-radius:var(--radius);color:#fff;cursor:pointer;border:none;width:100%;padding:14px;font-family:inherit;font-size:1rem;font-weight:600;transition:opacity .2s}.btn-primary:hover{opacity:.85}.btn-primary:disabled{opacity:.3;cursor:not-allowed}.btn-back{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;align-items:center;gap:4px;margin-bottom:16px;padding:8px 0;font-family:inherit;font-size:.85rem;display:flex}.btn-back:hover{color:var(--text)}.confirmation{text-align:center;padding:32px 0;animation:.4s both stepIn}.confirmation-icon{background:#0596691a;border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto 20px;display:flex}.confirmation-icon svg{width:32px;height:32px;color:var(--success)}.confirmation h2{margin-bottom:8px;font-size:1.25rem}.confirmation p{color:var(--text-secondary);margin-bottom:24px;font-size:.9rem}.error-msg{border-radius:var(--radius);color:#dc2626;background:#ef44440f;border:1px solid #ef444433;margin-bottom:16px;padding:12px 16px;font-size:.85rem}.prepay-notice{text-align:center;color:var(--text-tertiary);margin-top:12px;font-size:.8rem}.payment-summary{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:20px;padding:16px}.payment-summary__row{color:var(--text-secondary);justify-content:space-between;padding:6px 0;font-size:.9rem;display:flex}.payment-summary__total{border-top:1px solid var(--border);color:var(--text);margin-top:8px;padding-top:10px;font-size:1rem;font-weight:600}.tip-selector{margin-bottom:20px}.tip-options{flex-wrap:wrap;gap:8px;margin-top:8px;display:flex}.tip-option{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);cursor:pointer;flex-direction:column;align-items:center;gap:2px;min-width:64px;padding:10px 16px;font-size:.85rem;font-weight:500;transition:all .15s;display:flex}.tip-option:hover{border-color:var(--accent)}.tip-option--active{background:var(--accent);color:#fff;border-color:var(--accent)}.tip-option__amount{opacity:.7;font-size:.7rem}.tip-custom{align-items:center;gap:4px;max-width:160px;margin-top:10px;display:flex}.tip-custom__prefix{color:var(--text-secondary);font-size:1rem}.tip-custom__input{flex:1}.payment-form{margin-top:20px}.payment-form .btn-primary{width:100%;margin-top:20px}.confirmation-paid{justify-content:center;align-items:center;gap:8px;margin:12px 0;display:flex}.confirmation-paid__badge{background:var(--success);color:#fff;text-transform:uppercase;letter-spacing:.5px;border-radius:20px;padding:4px 12px;font-size:.75rem;font-weight:600;display:inline-block}.confirmation-paid__amount{color:var(--text);font-size:1.1rem;font-weight:600}
