*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;width:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Helvetica Neue,sans-serif;font-size:14px;line-height:1.5;color:#333;background:#fff;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#booking-widget-app{width:100%;height:100%;min-height:600px;padding:1.5rem;position:relative;display:flex;flex-direction:column}.widget-loading{display:flex;align-items:center;justify-content:center;min-height:600px;flex-direction:column;gap:1rem}.widget-loading .spinner{width:50px;height:50px;border:4px solid #f3f3f3;border-top:4px solid var(--widget-primary-color);border-radius:50%;animation:spin 1s linear infinite}.widget-loading p{color:#666;font-size:16px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.widget-header{margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid var(--widget-primary-color)}.widget-header h1{font-size:1.75rem;font-weight:700;color:var(--widget-primary-color);margin-bottom:.5rem}.widget-header .restaurant-info{color:#666;font-size:.95rem}.widget-header .restaurant-info i{margin-right:.5rem;color:var(--widget-primary-color)}.booking-steps{margin-bottom:2rem}.booking-steps .step-indicator{display:flex;justify-content:space-between;align-items:flex-start;position:relative}.booking-steps .step-indicator:before{content:"";position:absolute;top:20px;left:0;right:0;height:2px;background:#e5e7eb;z-index:0}.booking-steps .step-indicator .step{flex:1;text-align:center;position:relative;z-index:1;display:flex;flex-direction:column;align-items:center}.booking-steps .step-indicator .step .step-number{width:40px;height:40px;border-radius:50%;background:#e5e7eb;color:#666;display:flex;align-items:center;justify-content:center;font-weight:600;margin-bottom:.5rem;transition:all .3s ease}.booking-steps .step-indicator .step .step-label{font-size:.85rem;color:#666}.booking-steps .step-indicator .step.active .step-number{background:var(--widget-primary-color);color:#fff}.booking-steps .step-indicator .step.active .step-label{color:var(--widget-primary-color);font-weight:600}.booking-steps .step-indicator .step.completed .step-number{background:#10b981;color:#fff}.booking-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 1px 3px #0000001a;margin-bottom:1.5rem}.booking-card .card-title{font-size:1.25rem;font-weight:600;color:#111827;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.booking-card .card-title i{color:var(--widget-primary-color)}.booking-card .card-content{color:#4b5563}.form-group{margin-bottom:1.5rem}.form-group label{display:block;font-weight:600;color:#374151;margin-bottom:.5rem;font-size:.95rem}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:8px;font-size:1rem;transition:all .2s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--widget-primary-color);box-shadow:0 0 0 3px color-mix(in srgb,var(--widget-primary-color) 10%,transparent)}.form-group input.error,.form-group select.error,.form-group textarea.error{border-color:#ef4444}.form-group input.success,.form-group select.success,.form-group textarea.success{border-color:#22c55e}.form-group .error-message{color:#ef4444;font-size:.85rem;margin-top:.25rem}.form-group .help-text{color:#6b7280;font-size:.85rem;margin-top:.25rem}.promo-status{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;flex-shrink:0}.promo-status i{font-size:1rem}.promo-status.validating{background:#eff6ff;color:#3b82f6}.promo-status.valid{background:#dcfce7;color:#22c55e}.promo-status.invalid{background:#fef2f2;color:#ef4444}.time-slots{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.75rem;margin-top:1rem}.time-slots .time-slot{padding:.75rem;border:2px solid #e5e7eb;border-radius:8px;text-align:center;cursor:pointer;transition:all .2s ease;background:#fff;font-weight:500}.time-slots .time-slot:hover:not(.disabled){border-color:var(--widget-primary-color);background:var(--widget-primary-light)}.time-slots .time-slot.selected{border-color:var(--widget-primary-color);background:var(--widget-primary-color);color:#fff}.time-slots .time-slot.disabled{background:#f3f4f6;color:#9ca3af;cursor:not-allowed;opacity:.6}.btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.btn.btn-primary{background:var(--widget-primary-color);color:#fff}.btn.btn-primary:hover:not(:disabled){background:var(--widget-primary-hover)}.btn.btn-secondary{background:#e5e7eb;color:#374151}.btn.btn-secondary:hover:not(:disabled){background:#d1d5db}.btn:disabled{opacity:.5;cursor:not-allowed}.btn i{font-size:1.1rem}.button-group{display:flex;gap:1rem;margin-top:1.5rem}.button-group .btn{flex:1}.success-message{text-align:center;padding:3rem 1.5rem}.success-message .success-icon{width:80px;height:80px;border-radius:50%;background:#10b981;color:#fff;display:inline-flex;align-items:center;justify-content:center;margin-bottom:1.5rem;font-size:2.5rem}.success-message .success-icon i{color:#fff}.success-message h2{font-size:1.75rem;color:#111827;margin-bottom:1rem}.success-message p{color:#6b7280;font-size:1.1rem;margin-bottom:.5rem}.success-message .booking-reference{font-weight:700;color:var(--widget-primary-color);font-size:1.5rem;margin:1rem 0}.info-box{padding:1rem;border-radius:8px;margin-bottom:1rem;display:flex;align-items:flex-start;gap:.75rem}.info-box i{font-size:1.25rem;flex-shrink:0}.info-box.info{background:#eff6ff;border-left:4px solid #3b82f6;color:#1e40af}.info-box.info i{color:#3b82f6}.info-box.warning{background:var(--widget-primary-light);border-left:4px solid var(--widget-primary-color);color:#9a3412}.info-box.warning i{color:var(--widget-primary-color)}.info-box.error{background:#fef2f2;border-left:4px solid #ef4444;color:#991b1b}.info-box.error i{color:#ef4444}.widget-footer{margin-top:2rem;display:flex;align-items:center;justify-content:center;gap:.5rem;color:#9ca3af;font-size:.85rem}.widget-footer .footer-logo{height:60px;filter:grayscale(100%);opacity:.7;transition:filter .2s ease,opacity .2s ease}.widget-footer:hover .footer-logo{filter:grayscale(0%);opacity:1}@media(max-width:768px){#booking-widget-app{padding:1rem}.widget-header h1{font-size:1.5rem}.booking-card{padding:1rem}.time-slots{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:.5rem}.time-slots .time-slot{padding:.5rem;font-size:.9rem}.button-group{flex-direction:column}.booking-steps .step-indicator .step .step-label{font-size:.75rem}}@media(max-width:480px){.time-slots{grid-template-columns:repeat(3,1fr)}.success-message{padding:2rem 1rem}.success-message .success-icon{width:60px;height:60px;font-size:2rem}.success-message h2{font-size:1.5rem}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .3s ease}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}*:focus-visible{outline:2px solid var(--widget-primary-color);outline-offset:2px}
