:root{--primary: #0284c7;--primary-hover: #0369a1;--primary-light: #e0f2fe;--primary-border: #bae6fd;--success: #10b981;--danger: #ef4444;--warning: #f59e0b;--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #94a3b8;--bg: #f0f9ff;--card: #ffffff;--border: #e2e8f0;--border-hover: #cbd5e1;--radius-sm: 6px;--radius-md: 12px;--radius-lg: 20px;--shadow-sm: 0 1px 3px rgba(0,0,0,.07);--shadow-md: 0 4px 16px rgba(0,0,0,.09);--shadow-lg: 0 12px 40px rgba(0,0,0,.12)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,system-ui,sans-serif;font-size:15px;color:var(--text-primary);background:var(--bg);-webkit-font-smoothing:antialiased}.page{min-height:100vh;display:flex;flex-direction:column}.header{background:linear-gradient(135deg,#0ea5e9,#0284c7 60%,#0369a1);color:#fff;padding:0 24px;box-shadow:0 2px 12px #0284c759;position:sticky;top:0;z-index:100}.header-inner{max-width:700px;margin:0 auto;height:60px;display:flex;align-items:center;justify-content:space-between}.logo{display:flex;align-items:center;gap:10px}.logo-icon{font-size:22px}.logo-text{font-size:16px;font-weight:700;letter-spacing:-.3px}.header-tag{font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;background:#fff3;border:1px solid rgba(255,255,255,.3);padding:3px 10px;border-radius:99px}.main{flex:1;padding:32px 16px 48px;max-width:700px;margin:0 auto;width:100%}.step-indicator{display:flex;align-items:center;margin-bottom:28px;overflow:hidden}.step-item{display:flex;align-items:center;flex:1;min-width:0}.step-circle{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0;transition:all .2s;border:2px solid var(--border);background:var(--card);color:var(--text-muted)}.step-item.completed .step-circle{background:var(--primary);border-color:var(--primary);color:#fff}.step-item.active .step-circle{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 0 0 4px var(--primary-light)}.step-label{font-size:11px;font-weight:600;color:var(--text-muted);margin-left:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.step-item.active .step-label,.step-item.completed .step-label{color:var(--primary)}.step-line{flex:1;height:2px;background:var(--border);margin:0 4px;min-width:8px;transition:background .2s}.step-line.done{background:var(--primary)}.card{background:var(--card);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:28px 28px 24px;border:1px solid var(--border)}.step-title{font-size:20px;font-weight:800;color:var(--text-primary);letter-spacing:-.4px;margin-bottom:4px}.step-desc{font-size:13px;color:var(--text-muted);margin-bottom:20px}.btn-primary{background:var(--primary);color:#fff;border:none;padding:11px 24px;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;transition:background .15s,transform .1s,box-shadow .15s;box-shadow:0 2px 8px #0284c74d}.btn-primary:hover:not(:disabled){background:var(--primary-hover);box-shadow:0 4px 14px #0284c766}.btn-primary:active:not(:disabled){transform:scale(.98)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-back{background:none;border:1.5px solid var(--border);color:var(--text-secondary);padding:11px 20px;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;transition:all .15s}.btn-back:hover{border-color:var(--border-hover);background:#f8fafc}.btn-ghost{background:none;border:none;color:var(--primary);font-size:13px;font-weight:600;cursor:pointer;text-decoration:underline;padding:0}.step-actions{display:flex;align-items:center;justify-content:space-between;margin-top:24px;padding-top:20px;border-top:1px solid var(--border);gap:12px}.step-actions-end{display:flex;justify-content:flex-end;margin-top:24px;padding-top:20px;border-top:1px solid var(--border)}.branch-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;margin-bottom:8px}.branch-card{border:2px solid var(--border);border-radius:var(--radius-md);padding:18px;cursor:pointer;transition:all .2s;background:#fff;text-align:left;width:100%}.branch-card:hover{border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-light);transform:translateY(-1px)}.branch-card.selected{border-color:var(--primary);background:var(--primary-light);box-shadow:0 0 0 4px var(--primary-light)}.branch-icon{width:42px;height:42px;background:var(--primary-light);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;margin-bottom:14px;border:1px solid var(--primary-border)}.branch-name{font-size:14px;font-weight:700;color:var(--text-primary);margin-bottom:4px}.branch-address{font-size:12px;color:var(--text-secondary);line-height:1.4}.service-list{border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;margin-bottom:8px}.service-group-label{padding:8px 16px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);background:#f8fafc;border-bottom:1px solid var(--border)}.service-item{display:flex;align-items:center;padding:14px 16px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .12s;gap:12px;background:#fff}.service-item:last-child{border-bottom:none}.service-item:hover{background:#f8fafc}.service-item.selected{background:var(--primary-light);border-left:3px solid var(--primary)}.service-check{width:20px;height:20px;border-radius:50%;border:2px solid var(--border);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:10px;transition:all .15s}.service-item.selected .service-check{background:var(--primary);border-color:var(--primary);color:#fff}.service-info{flex:1;min-width:0}.service-name{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:2px}.service-desc{font-size:12px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.service-meta{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0}.chip{font-size:11px;padding:2px 8px;border-radius:99px;font-weight:600;white-space:nowrap}.chip-duration{background:#f1f5f9;color:var(--text-secondary);border:1px solid var(--border)}.chip-price{background:#ecfdf5;color:#059669;border:1px solid #a7f3d0}.calendar{border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;margin-bottom:8px;background:#fff}.calendar-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;background:linear-gradient(135deg,var(--primary-light),#f0f9ff);border-bottom:1px solid var(--primary-border)}.cal-month{font-size:15px;font-weight:700;color:var(--primary)}.cal-nav{width:32px;height:32px;border-radius:50%;border:1.5px solid var(--primary-border);background:#fff;color:var(--primary);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;line-height:1}.cal-nav:hover:not(:disabled){background:var(--primary);color:#fff;border-color:var(--primary)}.cal-nav:disabled{opacity:.35;cursor:not-allowed}.day-names{display:grid;grid-template-columns:repeat(7,1fr);padding:10px 16px 2px}.day-name{text-align:center;font-size:10px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.day-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;padding:6px 16px 16px}.day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:13px;font-weight:500;border:none;background:none;cursor:pointer;transition:all .12s;color:var(--text-primary);position:relative;width:100%}.day:hover:not(.day-disabled):not(.day-empty){background:var(--primary-light);color:var(--primary)}.day-disabled{color:var(--border-hover);cursor:not-allowed;font-weight:400}.day-empty{cursor:default}.day-selected{background:var(--primary)!important;color:#fff!important;font-weight:700;box-shadow:0 2px 8px #0284c766}.day-today:not(.day-selected){color:var(--primary);font-weight:700}.day-today:not(.day-selected):after{content:"";position:absolute;bottom:3px;left:50%;transform:translate(-50%);width:3px;height:3px;background:var(--primary);border-radius:50%}.cal-legend{display:flex;gap:16px;padding:10px 16px 12px;border-top:1px solid var(--border);background:#fafafa}.cal-legend span{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--text-muted)}.legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.legend-available{background:var(--primary-light);border:1.5px solid var(--primary-border)}.legend-unavailable{background:var(--border)}.legend-selected{background:var(--primary)}.cal-loading{padding:40px;text-align:center;color:var(--text-muted);font-size:13px}.slots-context{background:var(--primary-light);border:1px solid var(--primary-border);border-radius:var(--radius-sm);padding:10px 14px;font-size:13px;color:var(--primary);font-weight:500;margin-bottom:16px;display:flex;align-items:center;gap:8px}.slot-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:8px;margin-bottom:8px}.slot{padding:10px 6px;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:#fff;font-size:13px;font-weight:600;color:var(--text-primary);cursor:pointer;text-align:center;transition:all .12s}.slot:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}.slot-selected{background:var(--primary)!important;border-color:var(--primary)!important;color:#fff!important;box-shadow:0 2px 8px #0284c759}.no-slots{text-align:center;padding:32px;color:var(--text-muted);font-size:13px;background:#fafafa;border:1px dashed var(--border);border-radius:var(--radius-md)}.no-slots strong{display:block;font-size:15px;color:var(--text-secondary);margin-bottom:4px}.loading{padding:48px;text-align:center;color:var(--text-muted);font-size:14px}.spinner{width:28px;height:28px;border:3px solid var(--primary-light);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite;margin:0 auto 12px}@keyframes spin{to{transform:rotate(360deg)}}.error-banner{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;border-radius:var(--radius-sm);padding:10px 14px;font-size:13px;margin-bottom:16px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 16px}.form-group{margin-bottom:16px}.form-group-full{grid-column:1 / -1}.form-label{display:block;font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:5px;text-transform:uppercase;letter-spacing:.3px}.form-input{width:100%;padding:10px 12px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:14px;color:var(--text-primary);background:#fff;outline:none;transition:border-color .15s,box-shadow .15s;font-family:inherit}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.form-input::placeholder{color:var(--text-muted)}textarea.form-input{resize:vertical;min-height:80px}.required{color:var(--primary)}.patient-toggle{display:flex;gap:0;border:1.5px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;margin-bottom:20px}.toggle-btn{flex:1;padding:10px;border:none;background:#fff;font-size:13px;font-weight:600;color:var(--text-muted);cursor:pointer;transition:all .15s}.toggle-btn.active{background:var(--primary);color:#fff}.toggle-btn:first-child{border-right:1px solid var(--border)}.review-summary{border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;margin-bottom:20px}.review-section{border-bottom:1px solid var(--border)}.review-section:last-child{border-bottom:none}.review-section-label{padding:8px 16px 4px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);background:#f8fafc}.review-row{display:flex;align-items:flex-start;padding:10px 16px;gap:12px}.review-row+.review-row{border-top:1px solid #f1f5f9}.review-key{font-size:12px;color:var(--text-muted);font-weight:500;width:80px;flex-shrink:0;padding-top:1px}.review-val{font-size:14px;font-weight:600;color:var(--text-primary);flex:1}.review-sub{font-size:12px;color:var(--text-muted);font-weight:400;margin-top:2px}.terms-note{font-size:12px;color:var(--text-muted);text-align:center;margin-top:12px;line-height:1.5}.confirm-page{text-align:center}.confirm-icon{width:80px;height:80px;background:#ecfdf5;border:3px solid #6ee7b7;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:36px;margin:0 auto 20px;animation:pop .4s cubic-bezier(.175,.885,.32,1.275) forwards}@keyframes pop{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}.confirm-title{font-size:24px;font-weight:800;color:var(--text-primary);letter-spacing:-.5px;margin-bottom:6px}.confirm-subtitle{font-size:14px;color:var(--text-muted);margin-bottom:24px;line-height:1.5}.reference-box{background:var(--primary-light);border:1.5px solid var(--primary-border);border-radius:var(--radius-md);padding:16px 24px;margin-bottom:24px;display:inline-block}.reference-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--primary);margin-bottom:4px}.reference-number{font-size:28px;font-weight:800;color:var(--primary);letter-spacing:1px}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:99px;font-size:13px;font-weight:600;background:#fef3c7;color:#92400e;border:1px solid #fde68a;margin-bottom:24px}.confirm-summary{border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;text-align:left;margin-bottom:24px}.confirm-note{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:var(--radius-sm);padding:12px 16px;font-size:13px;color:#166534;line-height:1.5;margin-bottom:20px}.btn-new-booking{background:#fff;border:1.5px solid var(--primary);color:var(--primary);padding:11px 24px;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;transition:all .15s}.btn-new-booking:hover{background:var(--primary-light)}.footer{text-align:center;padding:20px;font-size:12px;color:var(--text-muted);border-top:1px solid var(--border);background:#fff}button,[role=button]{touch-action:manipulation}@media (max-width: 500px){.card{padding:20px 16px;border-radius:var(--radius-md)}.main{padding:20px 12px 40px}.form-grid,.branch-grid{grid-template-columns:1fr}.step-label,.header-tag{display:none}.slot-grid{grid-template-columns:repeat(3,1fr)}.step-actions{flex-direction:column-reverse;gap:10px}.step-actions .btn-primary,.step-actions .btn-back,.step-actions .btn-new-booking{width:100%;text-align:center}.cal-legend{flex-wrap:wrap;gap:10px}.reference-number{font-size:22px}.confirm-title{font-size:20px}}
