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