*{box-sizing:border-box;font-family:'Inter',system-ui,-apple-system,sans-serif}body{margin:0;background:linear-gradient(180deg,#f5f3ff,#eef2ff);padding:16px;color:#1e293b}.app{max-width:1100px;margin:auto;background:#fff;border-radius:24px;display:flex;overflow:hidden;box-shadow:0 10px 30px rgb(0 0 0 / .08)}@media (max-width:768px){.app{flex-direction:column}}.calendar{flex:2;padding:20px;border-right:1px solid #ede9fe}.next{background:#f5f3ff;padding:12px;border-radius:14px;margin-bottom:14px;font-size:.9rem;color:#4c1d95}.nextItem{cursor:pointer;margin-top:6px;padding:6px;border-radius:8px;transition:.2s}.nextItem:hover{background:#ede9fe}.legend{font-size:.8rem;margin-bottom:10px;display:flex;gap:12px}.legend span{display:flex;align-items:center;gap:6px}.dot{width:8px;height:8px;border-radius:50%;display:inline-block}.onlineDot{background:#7c3aed}.presencialDot{background:#16a34a}.gray{background:#94a3b8!important}.month-nav{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.month{font-weight:600;color:#6d28d9}.nav-btn{background:none;border:1px solid #ddd;border-radius:999px;padding:4px 12px;cursor:pointer;font-size:1rem}.nav-btn:hover{background:#f5f3ff}.weekdays{display:grid;grid-template-columns:repeat(7,1fr);font-size:.75rem;text-align:center;margin-bottom:6px;color:#64748b}.grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}.day{aspect-ratio:1;border-radius:14px;display:flex;align-items:center;justify-content:center;position:relative;background:#f8fafc;cursor:pointer;transition:.2s;font-size:.9rem}.day:hover{transform:translateY(-2px)}.day.selected{outline:2px solid #7c3aed;background:#f5f3ff}.day.disabled{opacity:.3;cursor:not-allowed}.day.no-attention{opacity:.5;cursor:default}.day.no-attention:hover{transform:none}.dots{position:absolute;bottom:6px;display:flex;gap:4px}.dot-day{width:6px;height:6px;border-radius:50%}.dot-day.online{background:#7c3aed}.dot-day.presencial{background:#16a34a}.dot-day.gray{background:#94a3b8}.panel{flex:1;padding:20px}.infoBox{background:#f8fafc;padding:14px;border-radius:12px;margin-bottom:14px;font-size:.95rem}.slots{display:flex;flex-direction:column;gap:10px}.slot{padding:12px;border-radius:12px;background:#fff;display:flex;justify-content:space-between;align-items:center;border:1px solid #e2e8f0;transition:.2s;cursor:pointer}.slot.active{border:2px solid #7c3aed;background:#f5f3ff}.slot-left{display:flex;flex-direction:column;gap:4px}.slot-time{font-weight:500}.slot-details{font-size:.75rem;color:#4b5563}.badge{font-size:.7rem;padding:4px 10px;border-radius:999px;font-weight:500;display:inline-flex;align-items:center;gap:6px}.online{background:#ede9fe;color:#5b21b6}.presencial{background:#dcfce7;color:#166534}.precio{font-size:.8rem;font-weight:600;color:#059669}.precio-especial{background:#fef3c7;color:#b45309;padding:2px 6px;border-radius:999px;font-size:.7rem;font-weight:700}button{border:none;border-radius:999px;padding:6px 14px;cursor:pointer;font-size:.85rem}.btn{background:#7c3aed;color:#fff;font-weight:500}button:disabled{background:#e2e8f0;cursor:not-allowed}.form{margin-top:16px;padding:16px;border-radius:14px;background:#fafaff}.form label{font-size:.75rem;color:#475569;display:block;margin-bottom:4px}.form input{width:100%;padding:10px;border-radius:999px;border:1px solid #ddd;margin-top:4px;margin-bottom:10px}.success{background:#ecfdf5;padding:16px;border-radius:12px;margin-top:10px;text-align:center;color:#065f46;font-size:.9rem}.error-msg{background:#fee2e2;color:#991b1b;padding:12px;border-radius:12px;margin-top:10px;font-size:.85rem}.loading{text-align:center;padding:20px;color:#6b7280}.global-spinner-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgb(255 255 255 / .92);backdrop-filter:blur(3px);display:flex;justify-content:center;align-items:center;z-index:9999;transition:opacity 0.4s ease,visibility 0.4s ease;opacity:1;visibility:visible}.global-spinner-overlay.hidden{opacity:0;visibility:hidden}.global-spinner-container{text-align:center;max-width:300px;padding:20px}.global-spinner{width:50px;height:50px;border:5px solid rgb(0 0 0 / .1);border-radius:50%;border-top-color:#4caf50;animation:spin 0.8s linear infinite;margin:0 auto}.spinner-message{margin-top:24px;font-size:1rem;line-height:1.5;color:#2c3e2f;font-weight:500;background:rgb(255 255 255 / .9);padding:12px 16px;border-radius:24px;box-shadow:0 2px 8px rgb(0 0 0 / .05);font-family:'Inter',sans-serif;animation:fadeInUp 0.3s ease}@keyframes fadeInUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}.slot.reserved{opacity:.7;background-color:#f0f0f0}.slot.reserved .btn.disabled{background-color:#aaa;cursor:not-allowed}.phone-wrapper{display:flex;align-items:center;background:#fff;border:1px solid #ddd;border-radius:999px;overflow:hidden;margin-top:4px;margin-bottom:10px}.phone-prefix{background:#fff0;padding:10px 0 10px 16px;font-weight:500;color:#333;font-size:.75rem;border-right:none}.phone-wrapper input{flex:1;border:none;padding:10px 16px 10px 8px;font-size:.75rem;outline:none;background:#fff0;border-radius:0;margin:0}.phone-wrapper input:focus{box-shadow:none}.phone-hint{display:block;font-size:.75rem;color:#888;margin-top:-8px;margin-bottom:10px;padding-left:16px}