*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f9fafb;color:#1f2937;line-height:1.5}#root{min-height:100vh;display:flex;flex-direction:column}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.2;margin-bottom:.5rem}h1{font-size:1.75rem}h2{font-size:1.5rem}h3{font-size:1.25rem}p{margin-bottom:1rem}button{font-family:inherit;font-size:1rem;font-weight:500;border:none;border-radius:.5rem;padding:.75rem 1rem;cursor:pointer;transition:all .2s ease;outline:none}button:disabled{opacity:.6;cursor:not-allowed}button:focus-visible{outline:2px solid #4f46e5;outline-offset:2px}input,textarea,select{font-family:inherit;font-size:1rem;padding:.75rem;border:1px solid #d1d5db;border-radius:.5rem;width:100%;transition:border-color .2s ease}input:focus,textarea:focus,select:focus{border-color:#4f46e5;outline:none}label{display:block;font-weight:500;margin-bottom:.5rem;font-size:.875rem}.container{max-width:500px;margin:0 auto;padding:1rem}.card{background:#fff;border-radius:1rem;padding:1.5rem;box-shadow:0 4px 12px #0000000d;margin-bottom:1rem}.text-center{text-align:center}.text-muted{color:#6b7280}.text-success{color:#10b981}.text-error{color:#ef4444}.bg-primary{background-color:#4f46e5;color:#fff}.bg-success{background-color:#10b981;color:#fff}.bg-error{background-color:#ef4444;color:#fff}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .3s ease-out}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin{animation:spin 1s linear infinite}@media (max-width: 640px){.container{padding:.75rem}.card{padding:1rem}h1{font-size:1.5rem}h2{font-size:1.25rem}}.service-card{border:2px solid #e5e7eb;border-radius:.75rem;padding:1rem;margin-bottom:.75rem;background:#fff;cursor:pointer;transition:all .2s ease}.service-card:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0000001a}.service-card.selected{border-color:#4f46e5;background-color:#f5f3ff;box-shadow:0 4px 12px #4f46e533}.time-slot{padding:.75rem .5rem;border:2px solid #10b981;border-radius:.5rem;background-color:#f0fdf4;color:#065f46;font-weight:500;cursor:pointer;transition:all .2s ease}.time-slot:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.time-slot.selected{background-color:#4f46e5;border-color:#4f46e5;color:#fff}.time-slot.unavailable{border-color:#ef4444;background-color:#fef2f2;color:#991b1b;cursor:not-allowed;opacity:.6}.step-indicator{display:flex;justify-content:space-between;margin-bottom:2rem;position:relative}.step-indicator:before{content:"";position:absolute;top:50%;left:0;right:0;height:2px;background-color:#e5e7eb;transform:translateY(-50%);z-index:1}.step{position:relative;z-index:2;width:2rem;height:2rem;border-radius:50%;background-color:#fff;border:2px solid #e5e7eb;display:flex;align-items:center;justify-content:center;font-weight:600;color:#6b7280}.step.active{border-color:#4f46e5;background-color:#4f46e5;color:#fff}.step.completed{border-color:#10b981;background-color:#10b981;color:#fff}.alert{padding:1rem;border-radius:.5rem;margin-bottom:1rem}.alert-success{background-color:#d1fae5;color:#065f46;border:1px solid #a7f3d0}.alert-error{background-color:#fee2e2;color:#991b1b;border:1px solid #fecaca}.alert-info{background-color:#dbeafe;color:#1e40af;border:1px solid #bfdbfe}.loading{display:inline-block;width:1rem;height:1rem;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin 1s linear infinite}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:2px}::-webkit-scrollbar-thumb:hover{background:#a1a1a1}
