:root{--color-bg: #0a0a0f;--color-surface: #12121a;--color-surface-hover: #1a1a25;--color-border: #2a2a3a;--color-text: #f0f0f5;--color-text-muted: #8888a0;--color-primary: #6366f1;--color-primary-hover: #818cf8;--color-success: #22c55e;--color-whatsapp: #25D366;--color-error: #ef4444;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--shadow-glow: 0 0 60px rgba(99, 102, 241, .15)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:DM Sans,system-ui,-apple-system,sans-serif;background:var(--color-bg);color:var(--color-text);line-height:1.6;min-height:100vh}.app{min-height:100vh;display:flex;flex-direction:column}.container{width:100%;max-width:520px;margin:0 auto;padding:2rem 1.5rem}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:2rem;box-shadow:var(--shadow-glow)}h1{font-size:2rem;font-weight:700;letter-spacing:-.02em;margin-bottom:.5rem}h2{font-size:1.25rem;font-weight:600;color:var(--color-text-muted);margin-bottom:2rem}.form-group{margin-bottom:1.5rem}label{display:block;font-size:.875rem;font-weight:500;color:var(--color-text-muted);margin-bottom:.5rem}input[type=text],input[type=tel],input[type=time],input[type=number],select{width:100%;padding:.875rem 1rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-size:1rem;font-family:inherit;transition:border-color .2s,box-shadow .2s}input:focus,select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #6366f133}input::placeholder{color:var(--color-text-muted);opacity:.6}.label-hint{font-weight:400;color:var(--color-text-muted);font-size:.8rem}.input-hint{display:block;font-size:.75rem;color:var(--color-success);margin-top:.5rem}.input-error{display:block;font-size:.75rem;color:var(--color-error);margin-top:.5rem}.weekday-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:.5rem}.weekday-btn{padding:.75rem .25rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);font-size:.75rem;font-weight:500;cursor:pointer;transition:all .2s}.weekday-btn:hover{background:var(--color-surface-hover)}.weekday-btn.selected{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.time-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:1rem 1.5rem;background:var(--color-primary);border:none;border-radius:var(--radius-md);color:#fff;font-size:1rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s}.btn:hover:not(:disabled){background:var(--color-primary-hover);transform:translateY(-1px)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-whatsapp{background:var(--color-whatsapp)}.btn-whatsapp:hover:not(:disabled){background:#1fb855}.btn-secondary{background:transparent;border:1px solid var(--color-border);color:var(--color-text)}.btn-secondary:hover:not(:disabled){background:var(--color-surface-hover)}.success-box{background:#22c55e1a;border:1px solid rgba(34,197,94,.3);border-radius:var(--radius-md);padding:1.5rem;margin-bottom:1.5rem}.success-box h3{color:var(--color-success);font-size:1.125rem;margin-bottom:.75rem}.success-box p{color:var(--color-text-muted);font-size:.9rem}.success-box code{display:block;background:var(--color-bg);padding:.75rem 1rem;border-radius:var(--radius-sm);margin-top:.75rem;font-size:.85rem;word-break:break-all;color:var(--color-primary)}.error-message{background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);padding:1rem;color:var(--color-error);margin-bottom:1rem;font-size:.9rem}.date-picker{display:flex;gap:.5rem;overflow-x:auto;padding-bottom:.5rem;margin-bottom:1.5rem}.date-btn{flex-shrink:0;display:flex;flex-direction:column;align-items:center;padding:.75rem 1rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all .2s;min-width:70px}.date-btn:hover{background:var(--color-surface-hover)}.date-btn.selected{background:var(--color-primary);border-color:var(--color-primary)}.date-btn .day-name{font-size:.7rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.date-btn.selected .day-name{color:#ffffffb3}.date-btn .day-num{font-size:1.25rem;font-weight:600;color:var(--color-text)}.date-btn.selected .day-num{color:#fff}.date-btn .month{font-size:.7rem;color:var(--color-text-muted)}.date-btn.selected .month{color:#ffffffb3}.slots-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:.5rem;margin-bottom:1.5rem}.slot-btn{padding:.75rem .5rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.slot-btn:hover{background:var(--color-surface-hover);border-color:var(--color-primary)}.slot-btn.selected{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.no-slots{text-align:center;padding:2rem;color:var(--color-text-muted)}.loading{display:flex;align-items:center;justify-content:center;padding:3rem;color:var(--color-text-muted)}.spinner{width:24px;height:24px;border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite;margin-right:.75rem}@keyframes spin{to{transform:rotate(360deg)}}.professional-name{font-size:1.5rem;font-weight:700;margin-bottom:.25rem}.section-label{font-size:.8rem;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted);margin-bottom:.75rem}.home-hero{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;min-height:100vh;padding:2rem}.home-hero h1{font-size:3rem;margin-bottom:1rem;background:linear-gradient(135deg,var(--color-primary) 0%,#a855f7 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.home-hero p{font-size:1.25rem;color:var(--color-text-muted);margin-bottom:2rem;max-width:400px}.home-hero .btn{width:auto;padding:1rem 2.5rem}.copy-btn{background:var(--color-surface-hover);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);padding:.5rem 1rem;font-size:.8rem;cursor:pointer;margin-top:.75rem;transition:all .2s}.copy-btn:hover{background:var(--color-primary);border-color:var(--color-primary)}.button-group{display:flex;flex-direction:column;gap:.75rem}.calendar-feed-box{background:#6366f114;border:1px solid rgba(99,102,241,.2);border-radius:var(--radius-md);padding:1.25rem;margin:1.5rem 0}.calendar-feed-label{font-weight:600;margin-bottom:.25rem}.calendar-feed-desc{font-size:.85rem;color:var(--color-text-muted);margin-bottom:1rem}.calendar-feed-actions{display:flex;gap:.5rem}.btn-small{padding:.5rem 1rem;font-size:.85rem;width:auto}.section-divider{height:1px;background:var(--color-border);margin:1.5rem 0}.bookings-list{display:flex;flex-direction:column;gap:1rem}.booking-day{background:var(--color-bg);border-radius:var(--radius-md);overflow:hidden}.booking-day-header{background:#6366f11a;padding:.75rem 1rem;font-weight:600;font-size:.9rem;color:var(--color-primary)}.booking-item{display:flex;align-items:center;padding:1rem;border-bottom:1px solid var(--color-border)}.booking-item:last-child{border-bottom:none}.booking-time{font-weight:600;font-size:1rem;width:60px;flex-shrink:0}.booking-details{flex:1}.booking-client{color:var(--color-text)}.booking-status{font-size:.75rem;margin-top:.25rem}.booking-status.reserved{color:#f59e0b}.booking-status.confirmed{color:var(--color-success)}.no-bookings{text-align:center;padding:3rem 1rem;color:var(--color-text-muted)}.no-bookings p{font-size:1rem}.cancel-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem 1rem}.cancel-card{text-align:center}.cancel-icon{font-size:3rem;margin-bottom:1rem}.cancel-title{font-size:1.5rem;margin-bottom:.5rem}.cancel-subtitle{color:var(--color-text-muted);margin-bottom:2rem}.cancel-details{background:var(--color-bg);border-radius:var(--radius-md);padding:1.5rem;margin-bottom:2rem;text-align:left}.cancel-detail-row{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid var(--color-border)}.cancel-detail-row:last-child{border-bottom:none}.cancel-detail-label{color:var(--color-text-muted);font-size:.875rem}.cancel-detail-value{font-weight:500}.btn-danger{background:var(--color-error)}.btn-danger:hover:not(:disabled){background:#dc2626}.cancel-success{color:var(--color-success)}.cancel-error{color:var(--color-error)}.metrics-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin:1.5rem 0}.metric-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1rem;text-align:center}.metric-value{font-size:1.75rem;font-weight:700;color:var(--color-primary);line-height:1}.metric-label{font-size:.7rem;color:var(--color-text-muted);margin-top:.5rem;text-transform:uppercase;letter-spacing:.05em}.reminders-section{background:#f59e0b14;border:1px solid rgba(245,158,11,.25);border-radius:var(--radius-md);padding:1.25rem;margin:.5rem 0}.reminder-alert{color:#f59e0b;font-weight:600}.reminders-desc{font-size:.85rem;color:var(--color-text-muted);margin-bottom:1rem}.reminders-list{display:flex;flex-direction:column;gap:.75rem}.reminder-item{display:flex;align-items:center;justify-content:space-between;gap:1rem;background:var(--color-bg);padding:.875rem 1rem;border-radius:var(--radius-sm)}.reminder-info{display:flex;flex-direction:column}.reminder-client{font-weight:500}.reminder-datetime{font-size:.8rem;color:var(--color-text-muted)}.btn-reminder{background:#f59e0b;white-space:nowrap;flex-shrink:0}.btn-reminder:hover:not(:disabled){background:#d97706}.reminder-sent{font-size:.7rem;color:var(--color-text-muted);font-weight:400}.booking-email{display:block;font-size:.75rem;color:var(--color-text-muted);margin-top:.15rem}.booking-reminder-status{margin-top:.5rem}.reminder-sent-badge,.reminder-pending-badge,.reminder-manual-badge{display:inline-flex;align-items:center;gap:.5rem;font-size:.7rem;padding:.25rem .5rem;border-radius:4px}.reminder-sent-badge{background:#22c55e26;color:var(--color-success)}.reminder-pending-badge{background:#6366f126;color:var(--color-primary)}.reminder-manual-badge{background:#f59e0b26;color:#f59e0b}.reminder-timestamp{opacity:.7;font-size:.65rem}@media (max-width: 480px){.container{padding:1rem}.card{padding:1.5rem}h1{font-size:1.5rem}.home-hero h1{font-size:2rem}.weekday-grid{grid-template-columns:repeat(7,1fr);gap:.25rem}.weekday-btn{padding:.5rem .15rem;font-size:.65rem}}
